Linux 学习笔记

Linux学习笔记

请切换web视图查看,表格比较大,方法:视图》》web板式视图

博客园不能粘贴图片吗

 http://wenku.baidu.com/view/bda1c3067fd5360cba1adb7d

目录

Linux学习笔记... 1

请切换web视图查看,表格比较大,方法:视图》》web板式视图... 1

1.      常用命令... 3

1.1文件处理命令... 3

1.2权限管理命令... 8

1.3文件搜索命令... 12

1.4帮助命令... 19

1.5压缩解压命令... 20

1.6网络通信指令... 23

1.7 Shell应用技巧... 25

2.      Vim/Vi 28

3.      引导... 34

4软件包的安装... 39

4.1挂载光盘... 39

5.用户管理... 40

5.1组管理... 41

5.2批量添加用户... 41

6. 进程管理... 44

6.2计划任务... 45

7. shell编程... 46

7.1 hello world. 46

7.2标准输入和输出... 46

7.2变量,位置变量$! $$ $# $@ $* $?,环境变量,运算符... 47

7.3if…else. 52

7.4for. 53

7.5awk. 54

7.6一个显示用户信息的脚本... 54

7.7一个杀死登陆用户的脚本... 56

结果如下... 56

脚本内容... 56

7.8select case. 57

select. 57

select+case. 57

case. 58

7.9while. 59

7.10批量添加用户... 59

7.11批量删除用户... 60

7.12break  .. continue. 60

7.13 shift,参数累加求和... 61

效果: 参数左移... 61

7.14用户执行脚本的权限... 62

sh script. 62

1.      对脚本有r权限... 62

2.      脚本所在目录要有r-x权限... 62

脚本直接执行... 62

1.      对脚本有rx权限... 62

2.      脚本所在目录有rx权限... 62

7.15正则表达式... 62

7.16截取字符串awk,cut,set. 65

awk 列操作... 66

第一行不执行,第一行先读取的... 66

所以加BEGIN.. 67

行操作... 67

选取某一行... 68

去掉某一行... 68

追加某一行或几行... 68

替换... 69

7.17定时任务... 69

8. 安装jdk. 71

[root@dc-01 java]#  rpm -qa | grep jdk. 71

java-1.6.0-openjdk-1.6.0.0-1.45.1.11.1.el6.i686. 71

卸载之:... 71

[root@dc-01 java]# yum -y remove java-1.6.0-openjdk-1.6.0.0-1.45.1.11.1.el6.i686. 71

查看系统位数... 71

下载对应的安装包... 71

http://pan.baidu.com/s/1qWnzJCK. 71

1.修改权限为可执行... 71

2.rpm –ivh 安装包... 71

3.vi /etc/profile 尾部添加环境变量... 72

79 JAVA_HOME=/usr/java/jdk1.7.0_67. 72

80 PATH=$JAVA_HOME/bin:$PATH.. 72

81 CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar. 72

82 export JAVA_HOME. 72

83 export PATH.. 72

84 export CLASSPATH.. 72

4. 执行source /etc/profile命令让修改生效。... 72

5.查看安装结果... 72

至此,安装jdk成功... 73

9. 安装Tomcat. 73

1.下载安装包,千万选好安装源,因为安装包的问题,硬是让我调试了一天,真是傻逼,重新官网下载安装之后立马可以用了... 73

http://tomcat.apache.org/download-70.cgi 73

2.解压到/usr/local 下,并重命名为tomcat. 73

#tar zxvf apache-tomcat-7.0.35.tar.gz /解压... 73

#mv apache-tomcat-7.0.35 apache-tomcat /更名... 73

#cd /apache-tomcat/bin/ /打开此目录... 74

#chmod 777 *.sh /加777权限... 74

#bash catalina.sh start /启动... 74

1.    常用命令

命令存放,哪些命令可以执行?

root:

/sbin /usr/sbin

all users:

/bin /usr/bin

bin--binary 二进制文件 Linux所有都是文件,都是二进制文件 usr—user sbin—super binary

1.1文件处理命令

文件处理命令

1

ls

英文原意是list   功能:显示目录文件 属性可以连着写,比如ls -ld

Eg

含义

-a    all

显示所有文件,包括隐藏文件

ls -a /

-l    long       -I 显示i节点

详细信息显示

[root@localhost ~]# ls -l total 68 -rw------- 1 root root  1211 Feb 14 04:02 anaconda-ks.cfg drwxr-xr-x 3 root root  4096 Feb 14 11:20 Desktop -rw-r--r-- 1 root root 31736 Feb 14 04:02 install.log -rw-r--r-- 1 root root     0 Feb 14 03:16 install.log.syslog drwxr-xr-x 2 root root  4096 Feb 14 17:36 test

drwxr-xr-x             2          root       root   4096      Feb 14 11:20 每三个表示权限   表示硬连接数   所有者    所属组  文件大小  创建时间 数据块 block  512字节 第一个字符表示如下: d  目录directory -          二进制文件 l  软链接文件 每三个分配如下: r—read 读   w—write写  x—execute执行 rwx         r-x          r-x 所有者u    所属组g      其他人o user         group        others

-d

查看目录属性

[root@localhost ~]# ls -ld /test drwxr-xr-x 3 root root 4096 Feb 14 17:42 /test

2

cd

切换目录

Cd  /

进入根目录

Cd [目录]

Cd ..

返回父级目录

3

pwd

英文:print working directory

查看当前目录

[root@localhost ~]# pwd /root

4

touch

创建空文件

[root@localhost test]# touch testfile [root@localhost test]# ls -l testfile -rw-r--r-- 1 root root 0 Feb 14 18:51 testfile

5

mkdir

英文:make directories

创建空目录

[root@localhost ~]# mkdir test

6

cp

英文:copy

复制文件 -R 复制目录

copy   [源文件,可多个] [目的目录] [root@localhost test]# cp /etc/inittab /etc/services /test [root@localhost test]# ls /test abc.txt  inittab  lost+found  samlee  services  testfile   将etc拷贝到test下 [root@localhost test]# cp -R /etc /test

/etc 主要是配置文件,很重要,记得备份 命令停止快捷键:Ctrl+c

7.

mv

英文:move

移动文件,改名

[root@localhost test]# ls /test abc.txt  etc  inittab  lost+found  samlee  services  testfile 改名: [root@localhost test]# mv services service  [root@localhost test]# ls /test abc.txt  etc  inittab  lost+found  samlee  service  testfile 移动: [root@localhost test]# mv /test/inittab /tmp/ [root@localhost test]# ls /test abc.txt  etc  lost+found  samlee  service  testfile 改名+移动: [root@localhost test]#  mv /test/testfile /tmp/file.test [root@localhost test]# ls /tmp file.test                                   scim-panel-socket:0-root gconfd-root                                 scim-socket-frontend-root inittab                                     ssh-yoUWCY4180 keyring-z1fmdW                              virtual-root.IYU2ep mapping-root                                vmware-config0 orbit-root                                  VMwareDnD scim-bridge-0.3.0.lockfile-0@localhost:0.0  vmware-root scim-bridge-0.3.0.socket-0@localhost:0.0    vmware-root-592157060 scim-helper-manager-socket-root

8

rm

remove

删除

[root@localhost test]# ls /test abc.txt  etc  lost+found  samlee  service 删除service [root@localhost test]# rm service rm: remove regular file `service'? y [root@localhost test]# ls /test abc.txt  etc  lost+found  samlee 删除不询问: [root@localhost test]# touch testfile [root@localhost test]# ls abc.txt  etc  lost+found  samlee  testfile [root@localhost test]# rm -f testfile [root@localhost test]# ls abc.txt  etc  lost+found  samlee

rm –f 目录名称  不提示,强制删除,在写脚本的时候用,因为没有yes交互 r表示删除,f表示强制

9

cat

concatenate and display files

查看

[root@localhost test]# cat /etc/issue CentOS release 5.5 (Final) Kernel \r on an \m

适合查看文件小,因为多的话会把前面的覆盖,不能翻页。 比如cat /etc/services

10

more

(空格)或f 显示下一页 (enter)显示下一行 q或Q 退出

分页查看

[root@localhost test]# more /etc/services

11

head

-num 文件名

查看文件前num行

[root@localhost test]# head -5 /etc/services # /etc/services: # $Id: services,v 1.42 2006/02/23 13:09:23 pknirsch Exp $ # # Network services, Internet style #

12

tail

-num  文件名 -f     文件名

查看文件尾num行 动态查看文件尾部信息

[root@localhost test]# tail -5 /etc/services com-bardac-dw   48556/tcp                       # com-bardac-dw com-bardac-dw   48556/udp                       # com-bardac-dw iqobject        48619/tcp                       # iqobject iqobject        48619/udp                       # iqobject # Local services [root@localhost test]# tail -f /etc/services

tail –f 为了监视日志文件,默认显示10行

13

ln

英文:link ln 文件名  目的目录 ln –s 文件名 目的目录 -s soft软连接

创建硬链接 创建软链接

[root@localhost test]# ln -s /etc/issue /issue.soft [root@localhost test]# ls -l /etc/issue /issue.soft -rw-r--r-- 1 root root 47 Apr 26  2010 /etc/issue lrwxrwxrwx 1 root root 10 Feb 14 16:51 /issue.soft -> /etc/issue   硬链接: [root@localhost test]# ln  /etc/issue /issue.hard [root@localhost test]# ls -l /etc/issue /issue.hard -rw-r--r-- 2 root root 47 Apr 26  2010 /etc/issue -rw-r--r-- 2 root root 47 Apr 26  2010 /issue.hard   拷贝: [root@localhost test]# cp /etc/issue /test/issue [root@localhost test]# ls -l /etc/issue /test/issue -rw-r--r-- 2 root root 47 Apr 26  2010 /etc/issue -rw-r--r-- 1 root root 47 Feb 14 20:31 /test/issue   拷贝并且不改变时间,比如某些备份 [root@localhost test]# cp -p /etc/issue /test/issue cp: overwrite `/test/issue'? y [root@localhost test]# ls -l /etc/issue /test/issue -rw-r--r-- 2 root root 47 Apr 26  2010 /etc/issue -rw-r--r-- 1 root root 47 Apr 26  2010 /test/issue

软连接文件类型是l 软连接所有人都有权限,但能不能访问取决于源文件 软连接时间值 是创建软连接的时间 相当于快捷方式   类似于copy,文件大小相同 不同于copy的是,它是同步更新的。   还有一个不同的是,拷贝的时间是不同,时间是创建的时间   一个i节点可以映射到多个文件,所以硬链接可以同步更新。

1.2权限管理命令

权限管理命令

14

chmod

change the permissions mode of a file

chmod[{ugo0}{+-=}[文件或目录][mode=421][文件或目录] 功能: 改变文件或目录权限     用数字表示 r--4 w--2 x—1 rwxr-xr--  754 rw-r-x—x  651     文件: r-car,more,head,tail w-echo,vi 可以修改内容 x-命令,脚本 目录: r-ls w-touch,mkdir,rm 对目录有这些权限 x-cd 对目录可以进去 所以,所有的目录都有rx权限,表示可以读取可以进去

[root@localhost test]# ls -l a -rwxr-x--- 1 root root 0 Feb 19 15:45 a [root@localhost test]# chmod o+rwx a [root@localhost test]# ls -l a -rwxr-xrwx 1 root root 0 Feb 19 15:45 a [root@localhost test]# chmod o-rw a [root@localhost test]# ls -l a -rwxr-x--x 1 root root 0 Feb 19 15:45 a [root@localhost test]# chmod g=r a [root@localhost test]# ls -l a -rwxr----x 1 root root 0 Feb 19 15:45 a [root@localhost test]# chmod g=rx a [root@localhost test]# ls -l a -rwxr-x--x 1 root root 0 Feb 19 15:45 a   [root@localhost test]# chmod 641 a [root@localhost test]# ls -l a -rw-r----x 1 root root 0 Feb 19 15:45 a

chmod u+权限 文件或目录-------给所属者增加权限 chmod u+权限 文件或目录-------给所属者减少权限   chmod g=权限 文件或目录-------给所属组赋予权限   chmod o -----------------------------------同u,为加减权限               用数字表示权限,直接赋值就可以  chmod 641 a

15

chown

change file ownership

改变所有者

[root@localhost test]# ls -l a -rw-r----x 1 root root 0 Feb 19 15:45 a [root@localhost test]# chown helen a [root@localhost test]# ls -l a -rw-r----x 1 helen root 0 Feb 19 15:45 a [root@localhost test]# chown nobody a [root@localhost test]# ls -l a -rw-r----x 1 nobody root 0 Feb 19 15:45 a

16

chgrp

change file group ownership

改变所属组

[root@localhost test]# ls -l a -rw-r----x 1 nobody root 0 Feb 19 15:45 a [root@localhost test]# chgrp adm a [root@localhost test]# ls -l a -rw-r----x 1 nobody adm 0 Feb 19 15:45 a

17

umask

查看创建文件的默认权限 改变默认权限 umask 权限掩码值

[root@localhost test]# mkdir newdir [root@localhost test]# ls -ld newdir drwxr-xr-x 2 root root 4096 Feb 20 10:40 newdir [root@localhost test]# umask 0022 [root@localhost test]# umask -S u=rwx,g=rx,o=rx

*

0022

特殊权限位 022-用户权限位,权限掩码值    777 022 755 022 就是表示755   SetUID 4 SetGID 2

chmod u+s        4755        2755 组id         6755同时SetUID和SetGID

*

Linux权限规则

缺省创建的文件不能授予可执行x权限

[root@localhost test]# touch testfile [root@localhost test]# ls -l testfile -rw-r--r-- 1 root root 0 Feb 20 10:50 testfile

虽然创建文件的默认权限是022,但创建的空文件testfile没有x权限

*

添加用户

[root@localhost test]# useradd miao [root@localhost test]# passwd miao Changing password for user miao. New UNIX password: BAD PASSWORD: it is too short Retype new UNIX password: passwd: all authentication tokens updated successfully.

添加用户信息 设置密码 设置密码

*

su -

切换用户

1.3文件搜索命令

Linux中所有都是文件,命令也是文件

文件搜索命令

18

which

查询命令所在的绝对路径

[root@localhost ~]# which chmod /bin/chmod [root@localhost ~]# whereis ls ls: /bin/ls /usr/share/man/man1p/ls.1p.gz /usr/share/man/man1/ls.1.gz

命令也是文件 whereis除了绝对路径,还包括帮助文档

19

find

查找文件或目录 find [搜索路径][搜索关键字]   -name 文件名 *匹配任意字符 init* ?匹配单个字符 init???   -size 文件大小 block数据块 512字节=0.5kb 大于+ 小于- 等于 find / -size 204800   -user 文件所有者   时间 天 ctime  atime  mtime 分钟 cmin  amin  mmin c—change改变,表示文件的属性被修改过,所有者、所属组、权限 a—access访问 m—modify修改,表示文件的内容被修改过 -之内,+超过 find /etc –mmin  -120 一分钟内被修改过 -type 文件类型  f 二进制文件                l 软连接文件                d 目录 连接符  -a and   逻辑与          -o or     逻辑或 2.  连接符 find …. –exec 命令{}\;           {}find查询的结果           \转义符,符号命令使用本身的含义           ;结果           -ok提示

[root@localhost ~]# find /etc -name init /etc/sysconfig/init   试验通配符和占位符 [root@localhost ~]# find /etc -name init* /etc/selinux/targeted/contexts/initrc_context /etc/sysconfig/init /etc/sysconfig/network-scripts/init.ipv6-global /etc/init.d /etc/mail/spamassassin/init.pre /etc/inittab /etc/initlog.conf /etc/rc.d/init.d   [root@localhost ~]# find /etc -name init??? /etc/inittab [root@localhost ~]# find /etc -name init? [root@localhost ~]# find /etc -name init?? /etc/init.d /etc/rc.d/init.d   查找用户 [root@localhost ~]# find /home -user helen /home/helen /home/helen/.bash_logout /home/helen/.kde /home/helen/.kde/Autostart /home/helen/.kde/Autostart/.directory /home/helen/.mozilla /home/helen/.mozilla/extensions /home/helen/.mozilla/plugins /home/helen/.bash_profile /home/helen/.bashrc /home/helen/.bash_history   测试转义字符 [root@localhost ~]# which rm alias rm='rm -i'         /bin/rm [root@localhost ~]# rm abc.txt rm: remove regular empty file `abc.txt'? [root@localhost ~]# \rm abc.txt   查找二进制文件 [root@host141 ~]# find /etc -name init* -a -type f /etc/inittab /etc/initlog.conf /etc/sysconfig/network-scripts/init.ipv6-global /etc/sysconfig/init /etc/selinux/targeted/contexts/initrc_context   测试连接符-exec [root@localhost ~]# find /etc -name inittab /etc/inittab [root@localhost ~]# find /etc -name inittab -exec ls -l {} \; -rw-r--r-- 1 root root 1666 Feb 14 04:02 /etc/inittab   [root@localhost ~]# cd /test [root@localhost test]# pwd /test [root@localhost test]# ls a  a.hard  a.soft  etc  issue  lost+found [root@localhost test]# find /test -name a.soft /test/a.soft [root@localhost test]# find /test -name a.soft -exec rm {} \; [root@localhost test]# ls a  a.hard  etc  issue  lost+found   测试连接符-ok [root@localhost test]# find /etc -name inittab -exec ls -l {} \; -rw-r--r-- 1 root root 1666 Feb 14 04:02 /etc/inittab [root@localhost test]# find /etc -name inittab -ok ls -l {} \; < ls ... /etc/inittab > ? y -rw-r--r-- 1 root root 1666 Feb 14 04:02 /etc/inittab   [root@localhost test]# ls a  a.hard  etc  issue  lost+found [root@localhost test]# find /test -name a.hard -ok rm {} \; < rm ... /test/a.hard > ? y [root@localhost test]# ls a  etc  issue  lost+found   [root@localhost test]# find /etc -name init* -a -type f -exec ls -l {} \; -rw-r--r-- 1 root root 28 Apr 10  2010 /etc/selinux/targeted/contexts/initrc_context -rw-r--r-- 1 root root 1068 Jul  4  2009 /etc/sysconfig/init -rwxr-xr-x 1 root root 5433 Jul  4  2009 /etc/sysconfig/network-scripts/init.ipv6-global -rw-r--r-- 1 root root 1299 Jan 21  2009 /etc/mail/spamassassin/init.pre -rw-r--r-- 1 root root 1666 Feb 14 04:02 /etc/inittab -rw-r--r-- 1 root root 658 Sep 29  2009 /etc/initlog.conf   测试根据i节点删除文件 [root@localhost test]# touch "a b"; [root@localhost test]# ls a  a b [root@localhost test]# touch -- -abc [root@localhost test]# ls a  a b  -abc   [root@localhost test]# rm -abc rm: invalid option -- a Try `rm ./-abc' to remove the file `-abc'. Try `rm --help' for more information. [root@localhost test]# rm a b rm: remove regular empty file `a'? a rm: cannot lstat `b': No such file or directory [root@localhost test]# rm a b rm: remove regular empty file `a'? y rm: cannot lstat `b': No such file or directory   [root@localhost test]# rm -- -abc "a b" rm: remove regular empty file `-abc'? y rm: remove regular empty file `a b'? y [root@localhost test]# ls [root@localhost test]#   [root@localhost test]# ls -i 1653280 a b  1653352 -abc [root@localhost test]# find . -inum 1653280 ./a b [root@localhost test]# find . -inum 1653280 -exec rm {} \; [root@localhost test]# ls -abc

*通配符   大范围查找只在晚上2点左右进行,因为访问人数少,只占用一部分资源               ?匹配单个字符,相当于占位     通常用>或者<                                 rm的别名是 rm-i 所以要提示,那么要使用本身的含义,加转义字符\           查找二进制文件                 查找inittab 查找并显示详细信息       进入test 显示当前目录   显示当前目录下的文件   查找a.soft文件   查找a.soft文件并删除 a.soft已删除     查找inittab并查看详细信息   提示的查看(为了试验,真正用在rm)                       查找init开头,文件类型是二进制文件的详细信息                   一些奇葩的创建文件             这时候想要删除文件就会出问题                     我们知道创建过程的时候可以这样删除,如果不知道呢?           查找i节点   .表示当前目录,即/test   根据i节点删除,万能

20

locate

list files in databases

locate [搜索关键字] locate file 可以查找所有跟file相关的文件,速度快 locate指令是根据数据库查找的,如果数据库中文件没有更新,那么就会找不到。   定期updatedb,则可以直接locate找到

21

updatedb

update the slocate database

建立整个系统目录文件的数据库

22

grep

grep [指定字串][源文件] 在文件中搜寻字串匹配的行,并输出

[root@localhost test]# grep tftp /etc/services tftp            69/tcp tftp            69/udp tftp-mcast      1758/tcp tftp-mcast      1758/udp mtftp           1759/udp subntbcst_tftp  247/tcp                         # SUBNTBCST_TFTP subntbcst_tftp  247/udp                         # SUBNTBCST_TFTP etftp           1818/tcp                        # Enhanced Trivial File Transfer Protocol etftp           1818/udp                        # Enhanced Trivial File Transfer Protocol tftps           3713/tcp                        # TFTP over TLS tftps           3713/udp                        # TFTP over TLS

查找和tftp相关的行

1.4帮助命令

帮助命令

23

man

manual

man [命令或配置文件] 获得帮助信息 命令和配置文件相同时优先查看命令的帮助 帮助分很多种,其中第一种是命令,第五种是配置文件,当名字相同时通过 man 5来查看配置文件

man ls  使用more查看,空格翻页,enter下一行   [root@localhost test]# man 5 passwd

passwd可以修改用户密码, 和一个配置文件同名

24

info

information

info [任何关键字] 获取帮助信息

25

whatis

whatis apropos[任何关键字] 获得索引的简短说明信息

[root@localhost test]# whatis whereis whereis              (1)  - locate the binary, source, and manual page files for a command

26

help

命令 –help help 内置命令

[root@localhost test]# ls --help

1.5压缩解压命令

windows可解压Linux所有,但相反不可

共同:zip 但压缩比不高,如果小文件建议使用

gzip 和 bzip2只能压缩文件且不保留源文件,但后者-k可以保留

27

gzip

GNU zip

gzip 选项[文件] 压缩后文件格式: .gz 只能压缩文件,不能压缩目录 不保留源文件   解压缩: gunzip 压缩文件 gzip –d 压缩文件

[root@localhost test]# ls etc  issue  lost+found  newfile [root@localhost test]# gzip newfile [root@localhost test]# ls etc  issue  lost+found  newfile.gz   不能压缩目录 [root@localhost test]# mkdir newdir [root@localhost test]# ls etc  issue  lost+found  newdir  newfile.gz [root@localhost test]# gzip newdir gzip: newdir is a directory – ignored   解压缩 [root@localhost test]# gzip -d newfile.gz [root@localhost test]# ls etc  issue  lost+found  newdir  newfile [root@localhost test]# gzip newfile [root@localhost test]# ls etc  issue  lost+found  newdir  newfile.gz [root@localhost test]# gunzip newfile.gz [root@localhost test]# ls etc  issue  lost+found  newdir  newfile

28

tar

打包目录 tar 选项[cvf][目录]   -c 产生.tar打包文件   -v 显示详细信息   -f 指定压缩后的文件名   -z 打包同时压缩 压缩后文件格式: .tar.gz     解压缩   -x 解包.tar文件   -v 显示详细信息   -f 指定解压文件   -z 解压缩

[root@localhost test]# ls etc  issue  lost+found  newdir  newfile [root@localhost test]# tar -zcf newdir.tar.gz newdir [root@localhost test]# ls etc  issue  lost+found  newdir  newdir.tar.gz  newfile   当没有后缀,或者不知道文件类型 [root@localhost test]# tar -zcf new newdir [root@localhost test]# ls -l new -rw-r--r-- 1 root root 113 Feb 26 14:56 new [root@localhost test]# file new new: gzip compressed data, from Unix, last modified: Thu Feb 26 14:56:08 2015   先打包再压缩 [root@localhost test]# tar -cf newdir2.tar newdir [root@localhost test]# gzip newdir2.tar [root@localhost test]# ls etc  issue  lost+found  new  newdir  newdir2.tar.gz  newdir.tar.gz  newfile   解压缩 [root@localhost test]# ls etc  issue  lost+found  new  newdir  newdir2.tar.gz  newdir.tar.gz  newfile [root@localhost test]# tar -zxf newdir.tar.gz [root@localhost test]# ls etc  issue  lost+found  new  newdir  newdir2.tar.gz  newdir.tar.gz  newfile [root@localhost test]# tar -zxf newdir2.tar.gz [root@localhost test]# ls etc  issue  lost+found  new  newdir  newdir2.tar.gz  newdir.tar.gz  newfile [root@localhost test]# rm -rf newdir [root@localhost test]# ls etc  issue  lost+found  new  newdir2.tar.gz  newdir.tar.gz  newfile [root@localhost test]# tar -zxf new [root@localhost test]# ls etc  issue  lost+found  new  newdir  newdir2.tar.gz  newdir.tar.gz  newfile

tar –zcf 打包后的名字 要打包的文件名     注:打包后的文件名可以没有后缀,但是为了辨识方便,养成良好习惯         看起来像是文本文件,但这种使用cat是无法查看的 使用file查看文件了性

29

zip

zip 选项[-r][压缩后文件名称][文件或目录] -r  压缩目录 功能:压缩文件或目录 压缩后文件格式:.zip 保留源文件 范例:   zip services.zip /etc/services         zip –r test.zip /test  压缩目录

30

unzip

unzip [压缩文件] 功能:解压.zip的压缩文件 范例:unzip test.zip

31

bzip2

bzip2 选项[-k][文件]          -k 产生压缩文件后保留源文件 不加k则和gzip相同,但压缩比很高 功能:压缩文件 压缩后文件格式: .bz2 范例:  bzip2 –k file1

32

bunzip2

bunzip2 选项[-k][压缩文件]         -k 解压缩后保留源文件 功能:解压缩 范例: bunzip2 –k file1.bz2

1.6网络通信指令

33

write

当用户登陆的时候,可以进行信息交互, 以Ctrl+D作为结束

[root@localhost test]# write helen this is a test,hello [helen@localhost ~]$   这里使用SSH登陆 Message from root@localhost.localdomain on pts/1 at 15:37 ... this is a test,hello

34

wall

登陆的所有人都会收到

35

ping

测试网络连通性 ping 192.168.1.1   和windows不同的是,Linux如果不ctrl+c终止就会一直进行下去   注意:   丢包率:packet loss   有时候数据存取不完整,检查网络设备。  ping上万次     如果ping不通,先ping本机,证明自己没问题,ping 127.0.0.1 回环地址,检查自己的设置。 不通的时候不一定是网络不通,有可能防火墙等屏蔽了,不要武断的判断网络有问题。

改变ping的次数 [root@localhost test]# ping -c 3 192.168.0.141 像windows一样定义ping的次数 PING 192.168.0.141 (192.168.0.141) 56(84) bytes of data. 64 bytes from 192.168.0.141: icmp_seq=1 ttl=128 time=0.568 ms 64 bytes from 192.168.0.141: icmp_seq=2 ttl=128 time=0.456 ms 64 bytes from 192.168.0.141: icmp_seq=3 ttl=128 time=0.451 ms   --- 192.168.0.141 ping statistics --- 3 packets transmitted, 3 received, 0% packet loss, time 2001ms rtt min/avg/max/mdev = 0.451/0.491/0.568/0.059 ms   默认64字节,改变数据包大小 [root@localhost test]# ping -s 300 192.168.0.141 PING 192.168.0.141 (192.168.0.141) 300(328) bytes of data. 308 bytes from 192.168.0.141: icmp_seq=1 ttl=128 time=0.517 ms

36

ifconfig

ifconfig 选项[-a][网卡设备标识]          -a 显示所有网卡信息 功能:查看网络设置信息 范例:ifconfig –a eth0 本机物理网卡 lo 回环网卡地址 ifconfig eth0 192.168.9.4 修改ip,仅本次生效 Linux基本:只有写入配置文件才会永久生效

37

shutdown

只有root可以执行

[root@localhost test]# shutdown -h now最好不要使用,立马关机 关机前wall一下大家保存,然后shutdown,有缓冲时间

38

reboot

重启,root,服务器通常不随便开关

1.7 Shell应用技巧

通常使用bash,查看cat /etc/shells

命令补全

按Tab,如果是唯一的则直接补全,如果不唯一则按两下之后出现候选命令

清屏

clear 或者Ctrl+l

清除光标前字符

Ctrl+u

查看以前的命令

history !123 执行第123条命令 方向键上下可以找到历史命令

定义别名   alias copy=cp alias xrm=”rm –r”组合要括起来   清除别名:unalias copy

[root@localhost test]# alias alias cp='cp -i' alias l.='ls -d .* --color=tty' alias ll='ls -l --color=tty' alias ls='ls --color=tty' alias mv='mv -i' alias rm='rm -i' alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde' 这是系统定义的别名   [root@localhost test]# alias copy=cp   自定义别名 [root@localhost test]# copy /etc/inittab .  拷贝到当前目录 [root@localhost test]# ls etc      issue       new     newdir2.tar.gz  newdir.zip  newfile.bz2 inittab  lost+found  newdir  newdir.tar.gz   newfile

输入、输出重定向   通标准I/O一样,Shell对于每一个进程预先定义3个文件描述字(0,1,2),分别对应: 0         (STDIN)标准输入 1         (STDOUT)标准输出 2         (STDERR)标准错误输出   >或>>输出重定向 范例: ---------------------------------------》》                               <输入重定向               2>错误除数重定向

[root@localhost test]# ls -l /tmp >tmp.msg [root@localhost test]# date > /tmp.msg [root@localhost test]# cat /tmp.msg Thu Feb 26 16:49:57 CST 2015 原内容被覆盖   使用>>追加进去 [root@localhost test]# ls -l /tmp >> /tmp.msg [root@localhost test]# cat /tmp.msg Thu Feb 26 16:49:57 CST 2015 total 92 drwx------ 3 root root 4096 Feb 13 20:52 gconfd-root drwx------ 2 root root 4096 Feb 25 10:19 keyring-djsYy2 drwx------ 2 root root 4096 Feb 13 20:52 keyring-z1fmdW srwxr-xr-x 1 root root    0 Feb 25 10:19 mapping-root drwx------ 2 root root 4096 Feb 26 14:32 orbit-root -rw-r--r-- 1 root root    6 Feb 26 16:32 scim-bridge-0.3.0.lockfile-0@localhost:0.0 srwxr-xr-x 1 root root    0 Feb 26 14:32 scim-bridge-0.3.0.socket-0@localhost:0.0 srw------- 1 root root    0 Feb 25 10:19 scim-helper-manager-socket-root srw------- 1 root root    0 Feb 25 10:19 scim-panel-socket:0-root srw------- 1 root root    0 Feb 25 10:19 scim-socket-frontend-root drwx------ 2 root root 4096 Feb 25 10:19 ssh-khlNme4534 drwx------ 2 root root 4096 Feb 25 10:19 virtual-root.U2Qf0Y drwxr-xr-x 2 root root 4096 Feb 25 09:34 vmware-root drwx------ 2 root root 4096 Feb 25 10:19 vmware-root-592157060   <输入重定向 可以写一个定时脚本,然后自动输出 [root@localhost test]# wall < /etc/issue   Broadcast message from root (Thu Feb 26 17:08:07 2015):   CentOS release 5.5 (Final) Kernel \r on an \m   2>错误除数重定向 晚上定期备份,如果出错,保存错误信息 [root@localhost test]# cp -R /usr /backup/usr.bak 2> /bak.error   [root@localhost test]# ls /kdls ls: /kdls: No such file or directory [root@localhost test]# ls /kdls 2> ls.err   将错误信息写入,这个在写自动化脚本时非常有用 [root@localhost test]# cat ls.err ls: /kdls: No such file or directory [root@localhost test]# ls /tmp 2> ls.err  如果不错则没有 gconfd-root                                 scim-helper-manager-socket-root keyring-djsYy2                              scim-panel-socket:0-root keyring-z1fmdW                              scim-socket-frontend-root mapping-root                                ssh-khlNme4534 orbit-root                                  virtual-root.U2Qf0Y scim-bridge-0.3.0.lockfile-0@localhost:0.0  vmware-root scim-bridge-0.3.0.socket-0@localhost:0.0    vmware-root-592157060

管道 将一个命令的输出传送给另一个命令,作为另一个命令的输入

[root@localhost test]# ls -l /etc | more 将ls -l /etc的输出传送给more,可以空格翻页,enter换行,q退出 [root@localhost test]# ls -l /etc | grep init 包含init的行 lrwxrwxrwx  1 root root      11 Feb 14 03:18 init.d -> rc.d/init.d -rw-r--r--  1 root root     658 Sep 29  2009 initlog.conf -rw-r--r--  1 root root    1666 Feb 14 04:02 inittab lrwxrwxrwx  1 root root      15 Feb 14 03:25 rc.sysinit -> rc.d/rc.sysinit   [root@localhost test]# wc -l /etc/services wc可以查看行数 –l表示line行 9249 /etc/services [root@localhost test]# ls -l /etc | grep init | wc –l 多个管道 这里是说:查看etc下包含init多少行 4

命令连接符 ; 用; 间隔的各命令按顺序依次执行。 && 前后命令的执行存在逻辑与关系,只有&&前面的命令执行成功后,它后面的命令才被执行。 || 前后命令的执行存在逻辑或关系,只有||前面的命令执行失败后,它后面的命令才被执行。

顺序执行 [root@localhost test]# pwd ; ls ;date /test etc      issue       ls.err  newdir2.tar.gz  newdir.zip  newfile.bz2 inittab  lost+found  new     newdir.tar.gz   newfile     tmp.msg Thu Feb 26 17:27:57 CST 2015 可以将长时间的命令,比如升级内核,顺序执行,错误记录   逻辑与 [root@localhost test]# write Mary < /home/helen/love.txt && rm /home/helen/love.txt 小伙定时表白,如果发送成功,则毁灭证据 [root@localhost test]# ls && pwd etc      issue       ls.err  newdir2.tar.gz  newdir.zip  newfile.bz2 inittab  lost+found  new     newdir.tar.gz   newfile     tmp.msg /test [root@localhost test]# lslsl && pwd bash: lslsl: command not found   逻辑或 相反,只有一个能执行成功。 [root@localhost test]# write Mary < /home/helen/love.txt || mail Mary < /home/helen/love.txt 如果发情书成功就行了,如果发情书失败则发邮件 [root@localhost test]# ls || pwd etc      issue       ls.err  newdir2.tar.gz  newdir.zip  newfile.bz2 inittab  lost+found  new     newdir.tar.gz   newfile     tmp.msg [root@localhost test]# sfld || pwd bash: sfld: command not found /test

命令替换符 将一个命令的输出作为另一个命令的参数 键盘1左边的符号`

[root@localhost test]# which touch  查看touch所在 /bin/touch [root@localhost test]# ls -l /bin/touch 查看详情 -rwxr-xr-x 1 root root 42284 Mar  1  2010 /bin/touch [root@localhost test]# ls -l `which touch` 可以直接做参数 -rwxr-xr-x 1 root root 42284 Mar  1  2010 /bin/touch

2.    Vim/Vi

[root@localhost ~]# vi /root/.vimrc

      1 set nu

      2 map ^P I#<ESC>

      3

[root@localhost ~]# vi /etc/inittab

[root@localhost ~]# grep -v "^#" /etc/inittab | more   可以把以#开头的行排除

第一级 – 存活 安装 vim 启动 vim 什么也别干!请先阅读 当你安装好一个编辑器后,你一定会想在其中输入点什么东西,然后看看这个编辑器是什么样子。但vim不是这样的,请按照下面的命令操作: 启 动Vim后,vim在 Normal 模式下。 让我们进入 Insert 模式,请按下键 i 。(陈皓注:你会看到vim左下角有一个–insert–字样,表示,你可以以插入的方式输入了) 此时,你可以输入文本了,就像你用“记事本”一样。 如果你想返回 Normal 模式,请按 ESC 键。 现在,你知道如何在 Insert 和 Normal 模式下切换了。下面是一些命令,可以让你在 Normal 模式下幸存下来: i → Insert 模式,按 ESC 回到 Normal 模式. x → 删当前光标所在的一个字符。 :wq → 存盘 + 退出 (:w 存盘, :q 退出)   (陈皓注::w 后可以跟文件名) dd → 删除当前行,并把删除的行存到剪贴板里 p → 粘贴剪贴板 推荐: hjkl (强例推荐使用其移动光标,但不必需) →你也可以使用光标键 (←↓↑→). 注: j 就像下箭头。 :help <command> → 显示相关命令的帮助。你也可以就输入 :help 而不跟命令。(陈皓注:退出帮助需要输入:q) 你能在vim幸存下来只需要上述的那5个命令,你就可以编辑文本了,你一定要把这些命令练成一种下意识的状态。于是你就可以开始进阶到第二级了。 当是,在你进入第二级时,需要再说一下 Normal 模式。在一般的编辑器下,当你需要copy一段文字的时候,你需要使用 Ctrl 键,比如:Ctrl-C。也就是说,Ctrl键就好像功能键一样,当你按下了功能键Ctrl后,C就不在是C了,而且就是一个命令或是一个快键键了,在VIM的Normal模式下,所有的键就是功能键了。这个你需要知道。 标记: 下面的文字中,如果是 Ctrl-λ我会写成 <C-λ>. 以 : 开始的命令你需要输入 <enter>回车,例如 — 如果我写成 :q 也就是说你要输入 :q<enter>. 第二级 – 感觉良好 上面的那些命令只能让你存活下来,现在是时候学习一些更多的命令了,下面是我的建议:(陈皓注:所有的命令都需要在Normal模式下使用,如果你不知道现在在什么样的模式,你就狂按几次ESC键) 各种插入模式 a → 在光标后插入 o → 在当前行后插入一个新行 O → 在当前行前插入一个新行 cw → 替换从光标所在位置后到一个单词结尾的字符 简单的移动光标 0 → 数字零,到行头 ^ → 到本行第一个不是blank字符的位置(所谓blank字符就是空格,tab,换行,回车等) $ → 到本行行尾 g_ → 到本行最后一个不是blank字符的位置。 /pattern → 搜索 pattern 的字符串(陈皓注:如果搜索出多个匹配,可按n键到下一个) 拷贝/粘贴 (陈皓注:p/P都可以,p是表示在当前位置之后,P表示在当前位置之前) P → 粘贴 yy → 拷贝当前行当行于 ddP Undo/Redo u → undo <C-r> → redo 打开/保存/退出/改变文件(Buffer) :e <path/to/file> → 打开一个文件 :w → 存盘 :saveas <path/to/file> → 另存为 <path/to/file> :x, ZZ 或 :wq → 保存并退出 (:x 表示仅在需要时保存,ZZ不需要输入冒号并回车) :q! → 退出不保存 :qa! 强行退出所有的正在编辑的文件,就算别的文件有更改。 :bn 和 :bp → 你可以同时打开很多文件,使用这两个命令来切换下一个或上一个文件。(陈皓注:我喜欢使用:n到下一个文件) 花点时间熟悉一下上面的命令,一旦你掌握他们了,你就几乎可以干其它编辑器都能干的事了。但是到现在为止,你还是觉得使用vim还是有点笨拙,不过没关系,你可以进阶到第三级了。 第三级 – 更好,更强,更快 先恭喜你!你干的很不错。我们可以开始一些更为有趣的事了。在第三级,我们只谈那些和vi可以兼容的命令。 更好 下面,让我们看一下vim是怎么重复自己的: . → (小数点) 可以重复上一次的命令 N<command> → 重复某个命令N次 下面是一个示例,找开一个文件你可以试试下面的命令: 2dd → 删除2行 3p → 粘贴文本3次 100idesu [ESC] → 会写下 “desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu “ . → 重复上一个命令—— 100 “desu “. 3. → 重复 3 次 “desu” (注意:不是 300,你看,VIM多聪明啊). 更强 你要让你的光标移动更有效率,你一定要了解下面的这些命令,千万别跳过。 NG → 到第 N 行 (陈皓注:注意命令中的G是大写的,另我一般使用 : N 到第N行,如 :137 到第137行) gg → 到第一行。(陈皓注:相当于1G,或 :1) G → 到最后一行。 按单词移动: w → 到下一个单词的开头。 e → 到下一个单词的结尾。 > 如果你认为单词是由默认方式,那么就用小写的e和w。默认上来说,一个单词由字母,数字和下划线组成(陈皓注:程序变量) > 如果你认为单词是由blank字符分隔符,那么你需要使用大写的E和W。(陈皓注:程序语句)   下面,让我来说说最强的光标移动: % : 匹配括号移动,包括 (, {, [. (陈皓注:你需要把光标先移到括号上) * 和 #:  匹配光标当前所在的单词,移动光标到下一个(或上一个)匹配单词(*是下一个,#是上一个) 相信我,上面这三个命令对程序员来说是相当强大的。 更快 你一定要记住光标的移动,因为很多命令都可以和这些移动光标的命令连动。很多命令都可以如下来干: <start position><command><end position> 例如 0y$ 命令意味着: 0 → 先到行头 y → 从这里开始拷贝 $ → 拷贝到本行最后一个字符 你可可以输入 ye,从当前位置拷贝到本单词的最后一个字符。 你也可以输入 y2/foo 来拷贝2个 “foo” 之间的字符串。 还有很多时间并不一定你就一定要按y才会拷贝,下面的命令也会被拷贝: d (删除 ) v (可视化的选择) gU (变大写) gu (变小写) 等等 (陈皓注:可视化选择是一个很有意思的命令,你可以先按v,然后移动光标,你就会看到文本被选择,然后,你可能d,也可y,也可以变大写等) 第四级 – Vim 超能力 你只需要掌握前面的命令,你就可以很舒服的使用VIM了。但是,现在,我们向你介绍的是VIM杀手级的功能。下面这些功能是我只用vim的原因。 在当前行上移动光标: 0 ^ $ f F t T , ; 0 → 到行头 ^ → 到本行的第一个非blank字符 $ → 到行尾 g_ → 到本行最后一个不是blank字符的位置。 fa → 到下一个为a的字符处,你也可以fs到下一个为s的字符。 t, → 到逗号前的第一个字符。逗号可以变成其它字符。 3fa → 在当前行查找第三个出现的a。 F 和 T → 和 f 和 t 一样,只不过是相反方向。 还有一个很有用的命令是 dt" → 删除所有的内容,直到遇到双引号—— "。 区域选择 <action>a<object> 或 <action>i<object> 在visual 模式下,这些命令很强大,其命令格式为 <action>a<object> 和 <action>i<object> action可以是任何的命令,如 d (删除), y (拷贝), v (可以视模式选择)。 object 可能是: w 一个单词, W 一个以空格为分隔的单词, s 一个句字, p 一个段落。也可以是一个特别的字符:"、 '、 )、 }、 ]。 假设你有一个字符串 (map (+) ("foo")).而光标键在第一个 o 的位置。 vi" → 会选择 foo. va" → 会选择 "foo". vi) → 会选择 "foo". va) → 会选择("foo"). v2i) → 会选择 map (+) ("foo") v2a) → 会选择 (map (+) ("foo"))   块操作: <C-v> 块操作,典型的操作: 0 <C-v> <C-d> I-- [ESC] ^ → 到行头 <C-v> → 开始块操作 <C-d> → 向下移动 (你也可以使用hjkl来移动光标,或是使用%,或是别的) I-- [ESC] → I是插入,插入“--”,按ESC键来为每一行生效。   在Windows下的vim,你需要使用 <C-q> 而不是 <C-v> ,<C-v> 是拷贝剪贴板。 自动提示: <C-n> 和 <C-p> 在 Insert 模式下,你可以输入一个词的开头,然后按 <C-p>或是<C-n>,自动补齐功能就出现了……   宏录制: qa 操作序列 q, @a, @@ qa 把你的操作记录在寄存器 a。 于是 @a 会replay被录制的宏。 @@ 是一个快捷键用来replay最新录制的宏。 示例 在一个只有一行且这一行只有“1”的文本中,键入如下命令: qaYp<C-a>q→ qa 开始录制 Yp 复制行. <C-a> 增加1. q 停止录制. @a → 在1下面写下 2 @@ → 在2 正面写下3 现在做 100@@ 会创建新的100行,并把数据增加到 103.   可视化选择: v,V,<C-v> 前面,我们看到了 <C-v>的示例 (在Windows下应该是<C-q>),我们可以使用 v 和 V。一但被选好了,你可以做下面的事: J → 把所有的行连接起来(变成一行) < 或 > → 左右缩进 = → 自动给缩进 (陈皓注:这个功能相当强大,我太喜欢了)   在所有被选择的行后加上点东西: <C-v> 选中相关的行 (可使用 j 或 <C-d> 或是 /pattern 或是 % 等……) $ 到行最后 A, 输入字符串,按 ESC。   分屏: :split 和 vsplit. 下面是主要的命令,你可以使用VIM的帮助 :help split. 你可以参考本站以前的一篇文章VIM分屏。 :split → 创建分屏 (:vsplit创建垂直分屏) <C-w><dir> : dir就是方向,可以是 hjkl 或是 ←↓↑→ 中的一个,其用来切换分屏。 <C-w>_ (或 <C-w>|) : 最大化尺寸 (<C-w>| 垂直分屏) <C-w>+ (或 <C-w>-) : 增加尺寸   结束语 上面是作者最常用的90%的命令。 我建议你每天都学1到2个新的命令。 在两到三周后,你会感到vim的强大的。 有时候,学习VIM就像是在死背一些东西。 幸运的是,vim有很多很不错的工具和优秀的文档。 运行vimtutor直到你熟悉了那些基本命令。 其在线帮助文档中你应该要仔细阅读的是 :help usr_02.txt. 你会学习到诸如  !, 目录,寄存器,插件等很多其它的功能。

  1. 安装 vim
  2. 启动 vim
  3. 什么也别干!请先阅读

当你安装好一个编辑器后,你一定会想在其中输入点什么东西,然后看看这个编辑器是什么样子。但vim不是这样的,请按照下面的命令操作:

  • 启 动Vim后,vim在 Normal 模式下。
  • 让我们进入 Insert 模式,请按下键 i 。(陈皓注:你会看到vim左下角有一个–insert–字样,表示,你可以以插入的方式输入了)
  • 此时,你可以输入文本了,就像你用“记事本”一样。
  • 如果你想返回 Normal 模式,请按 ESC 键。

现在,你知道如何在 Insert 和 Normal 模式下切换了。下面是一些命令,可以让你在 Normal 模式下幸存下来:

  • i → Insert 模式,按 ESC 回到 Normal 模式.
  • x → 删当前光标所在的一个字符。
  • :wq → 存盘 + 退出 (:w 存盘, :q 退出)   (陈皓注::w 后可以跟文件名)
  • dd → 删除当前行,并把删除的行存到剪贴板里
  • p → 粘贴剪贴板

推荐:

  • hjkl (强例推荐使用其移动光标,但不必需) →你也可以使用光标键 (←↓↑→). 注: j 就像下箭头。
  • :help <command> → 显示相关命令的帮助。你也可以就输入 :help 而不跟命令。(陈皓注:退出帮助需要输入:q)

你能在vim幸存下来只需要上述的那5个命令,你就可以编辑文本了,你一定要把这些命令练成一种下意识的状态。于是你就可以开始进阶到第二级了。 当是,在你进入第二级时,需要再说一下 Normal 模式。在一般的编辑器下,当你需要copy一段文字的时候,你需要使用 Ctrl 键,比如:Ctrl-C。也就是说,Ctrl键就好像功能键一样,当你按下了功能键Ctrl后,C就不在是C了,而且就是一个命令或是一个快键键了,在VIM的Normal模式下,所有的键就是功能键了。这个你需要知道。 标记:

  • 下面的文字中,如果是 Ctrl-λ我会写成 <C-λ>.
  • 以 : 开始的命令你需要输入 <enter>回车,例如 — 如果我写成 :q 也就是说你要输入 :q<enter>.

第二级 – 感觉良好 上面的那些命令只能让你存活下来,现在是时候学习一些更多的命令了,下面是我的建议:(陈皓注:所有的命令都需要在Normal模式下使用,如果你不知道现在在什么样的模式,你就狂按几次ESC键)

  1. 各种插入模式
    • a → 在光标后插入
    • o → 在当前行后插入一个新行
    • O → 在当前行前插入一个新行
    • cw → 替换从光标所在位置后到一个单词结尾的字符
  2. 简单的移动光标
    • 0 → 数字零,到行头
    • ^ → 到本行第一个不是blank字符的位置(所谓blank字符就是空格,tab,换行,回车等)
    • $ → 到本行行尾
    • g_ → 到本行最后一个不是blank字符的位置。
    • /pattern → 搜索 pattern 的字符串(陈皓注:如果搜索出多个匹配,可按n键到下一个)
  3. 拷贝/粘贴 (陈皓注:p/P都可以,p是表示在当前位置之后,P表示在当前位置之前)
    • P → 粘贴
    • yy → 拷贝当前行当行于 ddP
  4. Undo/Redo
    • u → undo
    • <C-r> → redo
  5. 打开/保存/退出/改变文件(Buffer)
    • :e <path/to/file> → 打开一个文件
    • :w → 存盘
    • :saveas <path/to/file> → 另存为 <path/to/file>
    • :x, ZZ 或 :wq → 保存并退出 (:x 表示仅在需要时保存,ZZ不需要输入冒号并回车)
    • :q! → 退出不保存 :qa! 强行退出所有的正在编辑的文件,就算别的文件有更改。
    • :bn 和 :bp → 你可以同时打开很多文件,使用这两个命令来切换下一个或上一个文件。(陈皓注:我喜欢使用:n到下一个文件)

    花点时间熟悉一下上面的命令,一旦你掌握他们了,你就几乎可以干其它编辑器都能干的事了。但是到现在为止,你还是觉得使用vim还是有点笨拙,不过没关系,你可以进阶到第三级了。 第三级 – 更好,更强,更快 先恭喜你!你干的很不错。我们可以开始一些更为有趣的事了。在第三级,我们只谈那些和vi可以兼容的命令。 更好 下面,让我们看一下vim是怎么重复自己的:

  6. . → (小数点) 可以重复上一次的命令
  7. N<command> → 重复某个命令N次

下面是一个示例,找开一个文件你可以试试下面的命令:

  • 2dd → 删除2行
  • 3p → 粘贴文本3次
  • 100idesu [ESC] → 会写下 “desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu desu “
  • . → 重复上一个命令—— 100 “desu “.
  • 3. → 重复 3 次 “desu” (注意:不是 300,你看,VIM多聪明啊).

更强 你要让你的光标移动更有效率,你一定要了解下面的这些命令,千万别跳过。

  1. NG → 到第 N 行 (陈皓注:注意命令中的G是大写的,另我一般使用 : N 到第N行,如 :137 到第137行)
  2. gg → 到第一行。(陈皓注:相当于1G,或 :1)
  3. G → 到最后一行。
  4. 按单词移动:
    1. w → 到下一个单词的开头。
    2. e → 到下一个单词的结尾。

    > 如果你认为单词是由默认方式,那么就用小写的e和w。默认上来说,一个单词由字母,数字和下划线组成(陈皓注:程序变量) > 如果你认为单词是由blank字符分隔符,那么你需要使用大写的E和W。(陈皓注:程序语句) 下面,让我来说说最强的光标移动:

  • % : 匹配括号移动,包括 (, {, [. (陈皓注:你需要把光标先移到括号上)
  • * 和 #:  匹配光标当前所在的单词,移动光标到下一个(或上一个)匹配单词(*是下一个,#是上一个)

相信我,上面这三个命令对程序员来说是相当强大的。 更快 你一定要记住光标的移动,因为很多命令都可以和这些移动光标的命令连动。很多命令都可以如下来干: <start position><command><end position> 例如 0y$ 命令意味着:

  • 0 → 先到行头
  • y → 从这里开始拷贝
  • $ → 拷贝到本行最后一个字符

你可可以输入 ye,从当前位置拷贝到本单词的最后一个字符。 你也可以输入 y2/foo 来拷贝2个 “foo” 之间的字符串。 还有很多时间并不一定你就一定要按y才会拷贝,下面的命令也会被拷贝:

  • d (删除 )
  • v (可视化的选择)
  • gU (变大写)
  • gu (变小写)
  • 等等

(陈皓注:可视化选择是一个很有意思的命令,你可以先按v,然后移动光标,你就会看到文本被选择,然后,你可能d,也可y,也可以变大写等) 第四级 – Vim 超能力 你只需要掌握前面的命令,你就可以很舒服的使用VIM了。但是,现在,我们向你介绍的是VIM杀手级的功能。下面这些功能是我只用vim的原因。 在当前行上移动光标: 0 ^ $ f F t T , ;

  • 0 → 到行头
  • ^ → 到本行的第一个非blank字符
  • $ → 到行尾
  • g_ → 到本行最后一个不是blank字符的位置。
  • fa → 到下一个为a的字符处,你也可以fs到下一个为s的字符。
  • t, → 到逗号前的第一个字符。逗号可以变成其它字符。
  • 3fa → 在当前行查找第三个出现的a。
  • F 和 T → 和 f 和 t 一样,只不过是相反方向。

还有一个很有用的命令是 dt" → 删除所有的内容,直到遇到双引号—— "。 区域选择 <action>a<object> 或 <action>i<object> 在visual 模式下,这些命令很强大,其命令格式为 <action>a<object> 和 <action>i<object>

  • action可以是任何的命令,如 d (删除), y (拷贝), v (可以视模式选择)。
  • object 可能是: w 一个单词, W 一个以空格为分隔的单词, s 一个句字, p 一个段落。也可以是一个特别的字符:"、 '、 )、 }、 ]。

假设你有一个字符串 (map (+) ("foo")).而光标键在第一个 o 的位置。

  • vi" → 会选择 foo.
  • va" → 会选择 "foo".
  • vi) → 会选择 "foo".
  • va) → 会选择("foo").
  • v2i) → 会选择 map (+) ("foo")
  • v2a) → 会选择 (map (+) ("foo"))

块操作: <C-v> 块操作,典型的操作: 0 <C-v> <C-d> I-- [ESC]

  • ^ → 到行头
  • <C-v> → 开始块操作
  • <C-d> → 向下移动 (你也可以使用hjkl来移动光标,或是使用%,或是别的)
  • I-- [ESC] → I是插入,插入“--”,按ESC键来为每一行生效。

在Windows下的vim,你需要使用 <C-q> 而不是 <C-v> ,<C-v> 是拷贝剪贴板。 自动提示: <C-n> 和 <C-p> 在 Insert 模式下,你可以输入一个词的开头,然后按 <C-p>或是<C-n>,自动补齐功能就出现了…… 宏录制: qa 操作序列 q, @a, @@

  • qa 把你的操作记录在寄存器 a。
  • 于是 @a 会replay被录制的宏。
  • @@ 是一个快捷键用来replay最新录制的宏。

示例 在一个只有一行且这一行只有“1”的文本中,键入如下命令:

  • qaYp<C-a>q→
    • qa 开始录制
    • Yp 复制行.
    • <C-a> 增加1.
    • q 停止录制.
  • @a → 在1下面写下 2
  • @@ → 在2 正面写下3
  • 现在做 100@@ 会创建新的100行,并把数据增加到 103.

可视化选择: v,V,<C-v> 前面,我们看到了 <C-v>的示例 (在Windows下应该是<C-q>),我们可以使用 v 和 V。一但被选好了,你可以做下面的事:

  • J → 把所有的行连接起来(变成一行)
  • < 或 > → 左右缩进
  • = → 自动给缩进 (陈皓注:这个功能相当强大,我太喜欢了)

在所有被选择的行后加上点东西:

  • <C-v>
  • 选中相关的行 (可使用 j 或 <C-d> 或是 /pattern 或是 % 等……)
  • $ 到行最后
  • A, 输入字符串,按 ESC。

分屏: :split 和 vsplit. 下面是主要的命令,你可以使用VIM的帮助 :help split. 你可以参考本站以前的一篇文章VIM分屏

  • :split → 创建分屏 (:vsplit创建垂直分屏)
  • <C-w><dir> : dir就是方向,可以是 hjkl 或是 ←↓↑→ 中的一个,其用来切换分屏。
  • <C-w>_ (或 <C-w>|) : 最大化尺寸 (<C-w>| 垂直分屏)
  • <C-w>+ (或 <C-w>-) : 增加尺寸

结束语

  • 上面是作者最常用的90%的命令。
  • 我建议你每天都学1到2个新的命令。
  • 在两到三周后,你会感到vim的强大的。
  • 有时候,学习VIM就像是在死背一些东西。
  • 幸运的是,vim有很多很不错的工具和优秀的文档。
  • 运行vimtutor直到你熟悉了那些基本命令。
  • 其在线帮助文档中你应该要仔细阅读的是 :help usr_02.txt.
  • 你会学习到诸如  !, 目录,寄存器,插件等很多其它的功能。

3.    引导

在 centOS 中的修改方法如下: 1.root登陆,免得老是sudo 2.打开/etc/inittab 文件    #vim /etc/inittab 3.在默认的 run level 设置中,可以看到第一行书写如:id:5:initdefault:(默认的 run level 等级为 5,即图形 界面) 4.将第一行的 5 修改为 3 即可。 5.保存文件后重启系统你就可以看见是启动的文本界面了。

# id:5:initdefault:   # System initialization. si::sysinit:/etc/rc.d/rc.sysinit   l0:0:wait:/etc/rc.d/rc 0 l1:1:wait:/etc/rc.d/rc 1 l2:2:wait:/etc/rc.d/rc 2 l3:3:wait:/etc/rc.d/rc 3 l4:4:wait:/etc/rc.d/rc 4 l5:5:wait:/etc/rc.d/rc 5 l6:6:wait:/etc/rc.d/rc 6   [root@localhost ~]# runlevel 5 3

# Default runlevel. The runlevels used by RHS are: #   0 - halt (Do NOT set initdefault to this) #   1 - Single user mode #   2 - Multiuser, without NFS (The same as 3, if you do not have networking) #   3 - Full multiuser mode #   4 - unused #   5 - X11 #   6 - reboot (Do NOT set initdefault to this) #   关机 单用户模式,只有root可以登录,没有界面 多用模式,没有界面,无NFS 多用户模式,没有图形界面,最多 可用户自己定义 系统缺省的,x11 reboot,重启   查看运行级别

[root@localhost ~]# ls /etc/rc.d/rc3.d K01dnsmasq         K80kdump            S19rpcgssd K02avahi-dnsconfd  K85mdmpd            S22messagebus K02NetworkManager  K87multipathd       S23setroubleshoot K02oddjobd         K87named            S25bluetooth K05conman          K88wpa_supplicant   S25netfs K05innd            K89dund             S25pcscd K05saslauthd       K89netplugd         S26acpid K05wdaemon         K89pand             S26apmd K10dc_server       K89rdisc            S26haldaemon K10psacct          K91capi             S26hidd K10tcsd            K99readahead_later  S26lm_sensors K12dc_client       S00microcode_ctl    S28autofs K15httpd           S02lvm2-monitor     S50hplip K20nfs             S03vmware-tools     S55sshd K20rwhod           S04readahead_early  S56cups K24irda            S05kudzu            S56rawdevices K25squid           S08ip6tables        S56xinetd K30spamassassin    S08iptables         S57vmware-tools-thinprint K35dovecot         S08mcstrans         S58ntpd K35smb             S09isdn             S80sendmail K35vncserver       S10network          S85gpm K35winbind         S11auditd           S90crond K36lisa            S12restorecond      S90xfs K50ibmasm          S12syslog           S95anacron K50netconsole      S13cpuspeed         S95atd K50tux             S13irqbalance       S97yum-updatesd K50vsftpd          S13portmap          S98avahi-daemon K69rpcsvcgssd      S14nfslock          S99firstboot K73ypbind          S15mdmonitor        S99local K74nscd            S18rpcidmapd        S99smartd [root@localhost ~]# [root@localhost ~]# ls -ld /etc/rc3.d lrwxrwxrwx 1 root root 10 Feb 14 03:25 /etc/rc3.d -> rc.d/rc3.d   [root@localhost ~]# /etc/rc.d/init.d/sshd Usage: /etc/rc.d/init.d/sshd {start|stop|restart|reload|condrestart|status} [root@localhost ~]# /etc/rc.d/init.d/sshd start Starting sshd:                                             [  OK  ] [root@localhost ~]# /etc/rc.d/init.d/sshd stop Stopping sshd:                                             [  OK  ] [root@localhost ~]# /etc/rc.d/init.d/sshd restart Stopping sshd:                                             [FAILED] Starting sshd:                                             [  OK  ] [root@localhost ~]# /etc/rc.d/init.d/sshd condrestart Stopping sshd:                                             [  OK  ] Starting sshd:                                             [  OK  ] [root@localhost ~]# /etc/rc.d/init.d/sshd status openssh-daemon (pid  28037) is running... [root@localhost ~]# /etc/rc.d/init.d/sshd reload Reloading sshd:                                            [  OK  ] [root@localhost ~]#

S22messagebus 关于启动,对应级别的配置 S-start 表示启动 K-kill   表示不启动 之所以设置kill是为了方便切换用户级别的时候关闭哪些服务 22   表示启动顺序,越小越先 messagebus  表示脚本名称   关闭启动 [root@localhost ~]# mv S03vmware-tools s03vmvare-tools 修改脚本或删除脚本,只要不是S开头就好   firmvare CMOS/BIOS  --POST   | BootLoader  Grub root-/boot kernel- initrd-   | Kernel  hardware   | init  PID=1   | /etc/inittab  id:runlebels:action:process   | initdefault   | /etc/rc.d/rc.sysinit   | /etc/rc.d/rc   | /etc/rc.d/rcN.d         软连接   开启与关闭方法 使用方法

[root@localhost ~]# ntsysv [root@localhost ~]# ntsysv --level 3

设置启动还是关闭 空格改变是否启动,*表示启动,空白表示不启动 Tab选择是否保存与返回

[root@localhost ~]# dmesg | grep eth0 eth0: no IPv6 routers present eth0: no IPv6 routers present eth0: no IPv6 routers present [root@localhost ~]# dmeg | grep eth1 bash: dmeg: command not found [root@localhost ~]# dmesg | grep eth1 [root@localhost ~]# dmesg | grep sda SCSI device sda: 41943040 512-byte hdwr sectors (21475 MB) sda: Write Protect is off sda: Mode Sense: 61 00 00 00 sda: cache data unavailable sda: assuming drive cache: write through SCSI device sda: 41943040 512-byte hdwr sectors (21475 MB) sda: Write Protect is off sda: Mode Sense: 61 00 00 00 sda: cache data unavailable sda: assuming drive cache: write through  sda: sda1 sda2 sda3 sda4 < sda5 > sd 0:0:0:0: Attached scsi disk sda SELinux: initialized (dev sda1, type ext3), uses xattr EXT3 FS on sda1, internal journal EXT3 FS on sda5, internal journal SELinux: initialized (dev sda5, type ext3), uses xattr EXT3 FS on sda2, internal journal SELinux: initialized (dev sda2, type ext3), uses xattr Adding 2096472k swap on /dev/sda3.  Priority:-1 extents:1 across:2096472k

判断硬件是否识别

[root@localhost ~]# ls /var /log ls: /log: No such file or directory /var: account  crash  empty  games  lib    lock  mail   nis  preserve  run    tmp  www cache    db     ftp    gdm    local  log   named  opt  racoon    spool  tux  yp [root@localhost ~]# grep sshd /var/log/messages [root@localhost ~]# grep syslog /var/log/messages Feb 25 10:39:53 localhost syslogd 1.4.1: restart. Feb 27 11:17:11 localhost syslogd 1.4.1: restart.

查看引导时文件错误

忘记密码

重启,5s倒计时,按Esc,进入启动项选择, 选择内核编辑,第二行 按e编辑 按e编辑 后面空格 1,表示进入单用户模式,单用户模式只有root可以登录且不需要密码 按b启动

给grub添加密码

123456加密md5

4软件包的安装

4.1挂载光盘

安装sudo这个软件

挂载光盘:

mkdir /mnt/cdrom mount /dev/cdrom /mnt/cdrom

前提是有光盘镜像,也就是VMware要设置光盘为镜像文件

查询:

rpm –q sudo rpm –qa |grep samba [root@localhost CentOS]# rpm -qa | grep samba samba-3.0.33-3.28.el5 system-config-samba-1.2.41-5.el5 samba-common-3.0.33-3.28.el5 samba-client-3.0.33-3.28.el5

查看和samba相关的软件包

误删文件

5.用户管理

用户管理

[root@DBserver ~]# more /etc/passwd

root:x:0:0:root:/root:/bin/bash 用户名:密码位:UID:GID:描述信息:宿主信息:shell

三种用户: 超级用户(root,uid=0) 普通用户 伪用户

将uid改为0即可获得root权限,后门

用户密码放在 /etc/shadow

root:$1$Gy//UTmq$00qIJOFSX5brjnPoERd91/:15552:0:99999:7::: 用户名:加密密码:最后一次修改时间(以天为单位19700701之后):最小时间间隔(通常为0,表示两次修改的最小天数) :最大时间间隔:警告时间(快到期提醒,默认7天):闲置时间(空白表示天天登录): 将shadow密码删除后不需要密码就可以登录

为什么普通用户可以更改密码

[root@localhost ~]# ls -l /usr/bin/passwd -rwsr-xr-x. 1 root root 25980 2月  22 2012 /usr/bin/passwd

SetUID权限,用户执行这个命令的时候将以这个程序的 所有者root的身份执行。

5.1组管理

[root@localhost ~]# more /etc/group sys:x:3:bin,adm 组名:组密码位:GID:组成员

5.2批量添加用户

vi /test/user.info miao01::1001:1::/home/miao01:/bin/bash miao02::1002:1::/home/miao02:/bin/bash miao03::1003:1::/home/miao03:/bin/bash miao04::1004:1::/home/miao04:/bin/bash

yy复制 p粘贴 dd删除

newusers < user.info   [root@localhost test]# tail -8 /etc/passwd webalizer:x:67:67:Webalizer:/var/www/usage:/sbin/nologin sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin tcpdump:x:72:72::/:/sbin/nologin helen:x:500:500:yue:/home/helen:/bin/bash miao01:x:1001:501::/home/miao01:/bin/bash miao02:x:1002:501::/home/miao02:/bin/bash miao03:x:1003:501::/home/miao03:/bin/bash miao04:x:1004:501::/home/miao04:/bin/bash   [root@localhost test]# ls /home helen  miao01  miao02  miao03  miao04   [root@localhost test]# pwunconv 取消shadow password功能   [root@localhost test]# vi pass.info       1 miao01:miaoruifeng       2 miao02:miaoruifeng       3 miao03:miaoruifeng       4 miao04:miaoruifeng   [root@localhost test]# chpasswd < pass.info   [root@localhost test]# tail -5 /etc/passwd helen:$6$hAI2Non/v8ILJHUB$hZRdcI84l6l8Z00SSSC47g/bZDvbw82elFrlkzw9/mgPzhtZ0DUZxEBZaKE.bg01YJ4KzC40enFZ9ICkQPK/U1:500:500:yue:/home/helen:/bin/bash miao01:$6$ss3Y3rTq5J/ZsM$RM4MxoMQY0hKQVoiYoDdIxd.rOxIvhhDX4KSAtwx/wz8HDi4R/6XPJjSFbaPF3GKOXhfp/4yxM42iqp3uudTi0:1001:501::/home/miao01:/bin/bash miao02:$6$v.82xwjZ0BM2$ALGUvJjUsccS6y.yE/S0gntEKtmvpriBL6Jd5sbr5AnySNrPi1Ay8gI4CDDNFr3U2X/i.Ai5sZqYFkFtu6rYV/:1002:501::/home/miao02:/bin/bash miao03:$6$SMGHf/SO2JW/M$8qFnwvCejx30Wg6RzpTVXyB3.hh7vYnOwkASEFQwowFZz7cZUQfYYLeTWCzspuJH8AbkWkdca4gQ3fwvhNWwZ0:1003:501::/home/miao03:/bin/bash miao04:$6$5JzRLvtHoJCYs3KG$0JuxD5CbBxMq1vIn49Xv/HGtiF.z.JW9PbdshbylEpTv6iMu7mBM2k8z2BOUi.i8prODMl/vGyNEXsRqcSq7C0:1004:501::/home/miao04:/bin/bash   [root@localhost test]# tail -5 /etc/shadow tail: cannot open `/etc/shadow' for reading: No such file or directory   因为取消了shadow,需要打开   [root@localhost test]# pwconv  开启shadow   [root@localhost test]# tail -5 /etc/shadow     密码添加成功 helen:$6$hAI2Non/v8ILJHUB$hZRdcI84l6l8Z00SSSC47g/bZDvbw82elFrlkzw9/mgPzhtZ0DUZxEBZaKE.bg01YJ4KzC40enFZ9ICkQPK/U1:16498:0:99999:7::: miao01:$6$ss3Y3rTq5J/ZsM$RM4MxoMQY0hKQVoiYoDdIxd.rOxIvhhDX4KSAtwx/wz8HDi4R/6XPJjSFbaPF3GKOXhfp/4yxM42iqp3uudTi0:16498:0:99999:7::: miao02:$6$v.82xwjZ0BM2$ALGUvJjUsccS6y.yE/S0gntEKtmvpriBL6Jd5sbr5AnySNrPi1Ay8gI4CDDNFr3U2X/i.Ai5sZqYFkFtu6rYV/:16498:0:99999:7::: miao03:$6$SMGHf/SO2JW/M$8qFnwvCejx30Wg6RzpTVXyB3.hh7vYnOwkASEFQwowFZz7cZUQfYYLeTWCzspuJH8AbkWkdca4gQ3fwvhNWwZ0:16498:0:99999:7::: miao04:$6$5JzRLvtHoJCYs3KG$0JuxD5CbBxMq1vIn49Xv/HGtiF.z.JW9PbdshbylEpTv6iMu7mBM2k8z2BOUi.i8prODMl/vGyNEXsRqcSq7C0:16498:0:99999:7:::

问题1:newusers:conmmand not found/// newusers: cannot lock /etc/passwd; try again later. 答:由于多用户操作密码文件未关闭而上锁,解决方法:删除:rm –rf /etc/*.lock 问题2:newusers: line 5: invalid line 答:第五行为空,删掉空行,不能空行。

限制su,用户授权 sudo可以让普通用户以root身份执行命令,权限精细化

visudo miao01 miao=/usr/sbin/useradd,/usr/sbin/userdel 用户主机名权限   sudo /usr/sbin/useradd miao  添加用户miao    [sudo] password for miao01:  输入miao01的密码来验证   bash-4.1$ sudo –l  查看自己可以使用哪些root权限 Matching Defaults entries for miao01 on this host:     requiretty, !visiblepw, always_set_home, env_reset, env_keep="COLORS     DISPLAY HOSTNAME HISTSIZE INPUTRC KDEDIR LS_COLORS", env_keep+="MAIL PS1     PS2 QTDIR USERNAME LANG LC_ADDRESS LC_CTYPE", env_keep+="LC_COLLATE     LC_IDENTIFICATION LC_MEASUREMENT LC_MESSAGES", env_keep+="LC_MONETARY     LC_NAME LC_NUMERIC LC_PAPER LC_TELEPHONE", env_keep+="LC_TIME LC_ALL     LANGUAGE LINGUAS _XKB_CHARSET XAUTHORITY",     secure_path=/sbin\:/bin\:/usr/sbin\:/usr/bin   User miao01 may run the following commands on this host: (root) /usr/sbin/useradd, (root) /usr/sbin/userdel     miao02 miao=/sbin/shutdown -h now 用户2只可以马上关机:sudo使命令精确化!

授权用户使用Apache·

首先名字叫做httpd 1.       查看httpd.conf权限 2.       找到httpd.conf 3.       rpm –ql httpd | more 4.       根据找到的路径查看权限 5.       ls –l /etc/httpd/conf/httpd.conf [root@miao ~]# ls -l /etc/httpd/conf/httpd.conf -rw-r--r--. 1 root root 34418 Aug  2  2013 /etc/httpd/conf/httpd.conf 由此看出,只有root有写权限   目标: 1.       编辑Apache配置文件 2.       使用Apache启动脚本 3.       更新网页 目标1方法(3种): 1.       设置用户为httpd所有者 chown 2.       改变所属组,把用户加入组,授予组w权限 3.       visudo 用户地址=/bin/vi /etc/httpd/conf/httpd.conf     bash-4.1$ sudo /bin/vi /etc/httpd/conf/httpd.conf 可以执行了 Error detected while processing /root/.vimrc: line    1: E518: Unknown option: nocopatible Press ENTER or type command to continue      目标2方法: 1.       查询httpd方法 1.       [root@miao ~]# /etc/rc.d/init.d/httpd 2.       Usage: httpd {start|stop|restart|condrestart|try-restart|force-reload|reload|status|fullstatus|graceful|help|configtest} 3.       给用户授权 4.       visudo 用户地址=/etc/rc.d/init.d/htppd start,/etc/rc,d/init.d/httpd reload,/etc/rc.d/init.d/httpd fullstatus,/etc/rc.d/init.d/httpd configtest 5.

  1. 1.       查看httpd.conf权限
  2. 2.       找到httpd.conf
  3. 3.       rpm –ql httpd | more
  4. 4.       根据找到的路径查看权限
  5. 5.       ls –l /etc/httpd/conf/httpd.conf

[root@miao ~]# ls -l /etc/httpd/conf/httpd.conf -rw-r--r--. 1 root root 34418 Aug  2  2013 /etc/httpd/conf/httpd.conf 由此看出,只有root有写权限 目标:

  1. 1.       编辑Apache配置文件
  2. 2.       使用Apache启动脚本
  3. 3.       更新网页

目标1方法(3种):

  1. 1.       设置用户为httpd所有者 chown
  2. 2.       改变所属组,把用户加入组,授予组w权限
  3. 3.       visudo 用户地址=/bin/vi /etc/httpd/conf/httpd.conf

bash-4.1$ sudo /bin/vi /etc/httpd/conf/httpd.conf 可以执行了 Error detected while processing /root/.vimrc: line    1: E518: Unknown option: nocopatible Press ENTER or type command to continue 目标2方法:

  1. 1.       查询httpd方法
  2. 1.       [root@miao ~]# /etc/rc.d/init.d/httpd
  3. 2.       Usage: httpd {start|stop|restart|condrestart|try-restart|force-reload|reload|status|fullstatus|graceful|help|configtest}
  4. 3.       给用户授权
  5. 4.       visudo 用户地址=/etc/rc.d/init.d/htppd start,/etc/rc,d/init.d/httpd reload,/etc/rc.d/init.d/httpd fullstatus,/etc/rc.d/init.d/httpd configtest
  6. 5.      
  7. 6.       进程管理

[root@miao ~]# pkill httpd 不用提取pid直接杀死进程

改变优先级

[root@miao ~]# ps -le | grep httpd 1 S     0  5683     1  0  80   0 -  5096 -      ?        00:00:00 httpd 5 S    48  5685  5683  0  80   0 -  5076 -      ?        00:00:00 httpd 5 S    48  5686  5683  0  80   0 -  5331 -      ?        00:00:00 httpd 5 S    48  5687  5683  0  80   0 -  5331 -      ?        00:00:00 httpd 5 S    48  5688  5683  0  80   0 -  5331 -      ?        00:00:00 httpd 5 S    48  5689  5683  0  80   0 -  5331 -      ?        00:00:00 httpd 5 S    48  5690  5683  0  80   0 -  5331 -      ?        00:00:00 httpd 5 S    48  5691  5683  0  80   0 -  5331 -      ?        00:00:00 httpd 5 S    48  5692  5683  0  80   0 -  5331 -      ?        00:00:00 httpd 5 S    48  5693  5683  0  80   0 -  5331 -      ?        00:00:00 httpd [root@miao ~]# /etc/rc.d/init.d/httpd stop Stopping httpd:                                            [  OK  ] [root@miao ~]# nice --5 /etc/rc.d/init.d/httpd start Starting httpd: httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1 for ServerName                                                            [  OK  ] [root@miao ~]# ps -le | grep httpd 1 S     0  5715     1  2  75  -5 -  5096 -      ?        00:00:00 httpd 5 S    48  5717  5715  0  75  -5 -  5076 -      ?        00:00:00 httpd 5 S    48  5718  5715  0  75  -5 -  5331 -      ?        00:00:00 httpd 5 S    48  5719  5715  0  75  -5 -  5331 -      ?        00:00:00 httpd 5 S    48  5720  5715  0  75  -5 -  5331 -      ?        00:00:00 httpd 5 S    48  5721  5715  0  75  -5 -  5331 -      ?        00:00:00 httpd 5 S    48  5722  5715  0  75  -5 -  5331 -      ?        00:00:00 httpd 5 S    48  5723  5715  0  75  -5 -  5331 -      ?        00:00:00 httpd 5 S    48  5724  5715  0  75  -5 -  5331 -      ?        00:00:00 httpd 5 S    48  5725  5715  0  75  -5 -  5331 -      ?        00:00:00 httpd

用户退出后进程继续运行

[root@miao ~]# nohup find / -name init* > /root/find.init.20150305 &

Ctrl+c终止 ctrl+z挂起

转到挂起的进程,前台执行

[root@miao ~]# jobs                [1]+  Stopped                 ps -aux | more [root@miao ~]# fg 1

转到后台执行

bg 1

top

6.2计划任务   

at 时间 命令

如果这个进程没有启动,手动启动一下

执行计划任务,查看计划任务,删除计划任务

把具体的时间添上,不知道的都写* 分钟小时天月星期命令/脚本 0    4      * *   *     0    18     * *   2,5                   每周二周五下午六点执行 0    18     * 1-3  2,5                   1到3月每周二周五下午六点执行 30   17     * *    1-5 /usr/bin/wall < /etc/issue 45   17     * *    1-5 /sbin/shutdown –h now */2  12-14   * 3-6,9-12 1-5 /bin/cp –r /etc/backup/etc.20150305 2>/backup/etc/etc.bak.err >/dev/null               每2分钟执行,错误信息保存

crontab

[root@miao ~]# ps -le | grep crond 1 S     0  2290     1  0  80   0 -   989 -      ?        00:00:00 crond [root@miao ~]# /etc/rc.d/init.d/crond start

  1. 7.       shell编程

7.1   hello world

[root@miao ~]# mkdir sh [root@miao ~]# ls Desktop    Music     Templates        find.init.20150305  sh Documents  Pictures  Videos           install.log         ?????? Downloads  Public    anaconda-ks.cfg  install.log.syslog [root@miao ~]# cd sh/ [root@miao sh]# vim hello.sh   #!/bin/bash #miao the first echo "Mr hello" world ,this is my first shell ~   [root@miao sh]# ./hello.sh   通过相对路径或者绝对路径执行 Mr hello world ,this is my first shell

7.2标准输入和输出

7.2变量,位置变量$! $$ $# $@ $* $?,环境变量,运算符

最好大写,以字母下划线开头,包含字母下划线数字。

查看变量

set | more

上面用的是分隔符,是键盘1左边的按键

$?表示上一个命令是否执行成功:0表示成功

sh -x 查看执行过程用+表示

2015年3月7日星期六

7.3if…else

由于服务器经常宕机(自己用pc做服务器的学校),需要经常查看Apache是否死掉,若死掉则重启,写了脚本如下 [root@miao test]# cat test.apache #!/bin/sh #"if ...else" usage #Using this program to show your system's services.   echo "Now, the web services of this Linux system will be detext..." echo   #Detect www service  web=`/usr/bin/pgrep httpd`  if [ "$web" != "" ]  then         echo "The Web service is running."  else         echo "The Web service is NOT running."         /etc/rc.d/init.d/httpd start  fi   效果如下:

[root@miao test]# cat test.apache #!/bin/sh #"if ...else" usage #Using this program to show your system's services.   echo "Now, the web services of this Linux system will be detext..." echo   #Detect www service  web=`/usr/bin/pgrep httpd`  if [ "$web" != "" ]  then         echo "The Web service is running."  else         echo "The Web service is NOT running."         /etc/rc.d/init.d/httpd start  fi

[root@miao test]# cat test.apache #!/bin/sh #"if ...else" usage #Using this program to show your system's services.   echo "Now, the web services of this Linux system will be detext..." echo   #Detect www service  web=`/usr/bin/pgrep httpd`  if [ "$web" != "" ]  then         echo "The Web service is running."  else         echo "The Web service is NOT running."         /etc/rc.d/init.d/httpd start  fi

7.4for

7.5awk

-F指定分隔符为:,若不指定则为空格,$1开始代表分割的每一部分 查找uid为0 的用户

查找用户密码位空的用户,注意长度的表示

7.6一个显示用户信息的脚本

7.7一个杀死登陆用户的脚本

结果如下

脚本内容

7.8select case

select     select+case       case

7.9while

7.10批量添加用户

7.11批量删除用户

7.12break  .. continue

7.13 shift,参数累加求和

效果: 参数左移

7.14用户执行脚本的权限

sh script 对脚本有r权限 脚本所在目录要有r-x权限   脚本直接执行 1.       对脚本有rx权限 2.       脚本所在目录有rx权限

  1. 对脚本有r权限
  2. 脚本所在目录要有r-x权限

脚本直接执行

  1. 1.       对脚本有rx权限
  2. 2.       脚本所在目录有rx权限

7.15正则表达式

7.16截取字符串awk,cut,set

awk 列操作           第一行不执行,第一行先读取的   所以加BEGIN       行操作

选取某一行     去掉某一行   追加某一行或几行     替换

7.17定时任务

  1. 8.       安装jdk

8.1卸载原装openjdk

[root@dc-01 java]#  rpm -qa | grep jdk java-1.6.0-openjdk-1.6.0.0-1.45.1.11.1.el6.i686    卸载之:  [root@dc-01 java]# yum -y remove java-1.6.0-openjdk-1.6.0.0-1.45.1.11.1.el6.i686

8.2下载安装包

查看系统位数

下载对应的安装包

http://pan.baidu.com/s/1qWnzJCK

8.3安装

1.修改权限为可执行

2.rpm –ivh 安装包

3.vi /etc/profile 尾部添加环境变量

79 JAVA_HOME=/usr/java/jdk1.7.0_67  80 PATH=$JAVA_HOME/bin:$PATH  81 CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar  82 export JAVA_HOME  83 export PATH      84 export CLASSPATH

4. 执行source /etc/profile命令让修改生效。

5.查看安装结果

至此,安装jdk成功

  1. 9.       安装Tomcat

1.下载安装包,千万选好安装源,因为安装包的问题,硬是让我调试了一天,真是傻逼,重新官网下载安装之后立马可以用了

http://tomcat.apache.org/download-70.cgi

2.解压到/usr/local 下,并重命名为tomcat

#tar zxvf apache-tomcat-7.0.35.tar.gz /解压 #mv apache-tomcat-7.0.35 apache-tomcat /更名 #cd /apache-tomcat/bin/ /打开此目录 #chmod 777 *.sh /加777权限 #bash catalina.sh start /启动

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏散尽浮华

linux系统终端命令提示符设置(PS1)记录

PS(Prompt Sign)指的是命令提示符,在日常运维工作中为了方面操作管理,有时会设定PS1环境变量。 废话不多说,下面开始记录下Linux中PS1设置 ...

2078
来自专栏FreeBuf

Powershell编码与混淆

在powershell中最常使用的编码就是base64编码了,今天主要说一下Invoke-Obfuscation 这个powershell混淆编码框架,这也是著...

2087
来自专栏比原链

Bytom移动端钱包SDK开发基础

Gitee地址:https://gitee.com/BytomBlockchain/bytom

1004
来自专栏比原链

Bytom移动端钱包SDK开发基础

Gitee地址:https://gitee.com/BytomBlockchain/bytom

451
来自专栏转载gongluck的CSDN博客

跟我一起写Makefile

makefile 介绍 make命令执行时,需要一个 makefile 文件,以告诉make命令如何去编译和链接程序。 首先,我们用一个示例来说明makefil...

3547
来自专栏用户2442861的专栏

跟我一起写Makefile:MakeFile介绍

http://wiki.ubuntu.org.cn/%E8%B7%9F%E6%88%91%E4%B8%80%E8%B5%B7%E5%86%99Makefile:...

412
来自专栏阮一峰的网络日志

Vim 配置入门

Vim 的配置不太容易,它有自己的语法,许许多多的命令。我总是记不清楚,所以就整理了下面这篇文章,列出主要配置项的含义。

451
来自专栏Laoqi's Linux运维专列

Linux入门到精pao通lu

1233
来自专栏企鹅号快讯

linux etc下 passwd、shadow和group文件详解

在linux操作系统中, /etc/passwd文件中的每个用户都有一个对应的记录行,记录着这个用户的一下基本属性。该文件对所有用户可读。 /etc/shado...

2029
来自专栏Vamei实验室

Linux的“壳”

在上一篇文章中,我们已经初尝了Shell的好处。由于我们后面将大量借助Shell,所以在这里先简要介绍一下这件工具。 什么是Shell 我们已经说过,Shell...

1645

扫描关注云+社区