linux命令大全
原文链接:https://blog.csdn.net/boshuzhang/article/details/51122457
原文链接:https://blog.csdn.net/ljianhui/article/details/11100625
- cd /root/Docements # 切换到目录/root/Docements
- cd ./path # 切换到当前目录下的path目录中,“.”表示当前目录
- cd ../path # 切换到上层目录中的path目录中,“..”表示上一层目录
- -l :列出长数据串,包含文件的属性与权限数据等
- -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)
- -d :仅列出目录本身,而不是列出目录的文件数据
- -h :将文件容量以较易读的方式(GB,kB等)列出来
- -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来
- ls -l #以长数据串的形式列出当前目录下的数据文件和目录
- ls -lR #以长数据串的形式列出当前目录下的所有文件
- grep [-acinv] [--color=auto] '查找字符串' filename
- -a :将binary文件以text文件的方式查找数据
- -c :计算找到‘查找字符串’的次数
- -i :忽略大小写的区别,即把大小写视为相同
- -v :反向选择,即显示出没有‘查找字符串’内容的那一行
- # 例如:
- # 取出文件/etc/man.config中包含MANPATH的行,并把找到的关键字加上颜色
- grep --color=auto 'MANPATH' /etc/man.config
- # 把ls -l的输出中包含字母file(不区分大小写)的内容输出
- ls -l | grep -i file
- find [PATH] [option] [action]
- # 与时间有关的参数:
- -mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件;
- -mtime +n : 列出在n天之前(不含n天本身)被更改过的文件名;
- -mtime -n : 列出在n天之内(含n天本身)被更改过的文件名;
- -newer file : 列出比file还要新的文件名
- # 例如:
- find /root -mtime 0 # 在当前目录下查找今天之内有改动的文件
- # 与用户或用户组名有关的参数:
- -user name : 列出文件所有者为name的文件
- -group name : 列出文件所属用户组为name的文件
- -uid n : 列出文件所有者为用户ID为n的文件
- -gid n : 列出文件所属用户组为用户组ID为n的文件
- # 例如:
- find /home/ljianhui -user ljianhui # 在目录/home/ljianhui中找出所有者为ljianhui的文件
- # 与文件权限及名称有关的参数:
- -name filename :找出文件名为filename的文件
- -size [+-]SIZE :找出比SIZE还要大(+)或小(-)的文件
- -tpye TYPE :查找文件的类型为TYPE的文件,TYPE的值主要有:一般文件(f)、设备文件(b、c)、
- 目录(d)、连接文件(l)、socket(s)、FIFO管道文件(p);
- -perm mode :查找文件权限刚好等于mode的文件,mode用数字表示,如0755;
- -perm -mode :查找文件权限必须要全部包括mode权限的文件,mode用数字表示
- -perm +mode :查找文件权限包含任一mode的权限的文件,mode用数字表示
- # 例如:
- find / -name passwd # 查找文件名为passwd的文件
- find . -perm 0755 # 查找当前目录中文件权限的0755的文件
- find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte
- -a :将文件的特性一起复制
- -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份
- -i :若目标文件已经存在时,在覆盖时会先询问操作的进行
- -r :递归持续复制,用于目录的复制行为
- -u :目标文件与源文件有差异时才会复制
- cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2
- cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中
- -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖
- -i :若目标文件已经存在,就会询问是否覆盖
- -u :若目标文件已经存在,且比目标文件新,才会更新
- mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中
- mv file1 file2 # 把文件file1重命名为file2
- -f :就是force的意思,忽略不存在的文件,不会出现警告消息
- -i :互动模式,在删除前会询问用户是否操作
- -r :递归删除,最常用于目录删除,它是一个非常危险的参数
- rm -i file # 删除文件file,在删除之前会询问是否进行该操作
- rm -fr dir # 强制删除目录dir中的所有文件
- -A :所有的进程均显示出来
- -a :不与terminal有关的所有进程
- -u :有效用户的相关进程
- -x :一般与a参数一起使用,可列出较完整的信息
- -l :较长,较详细地将PID的信息列出
- ps aux # 查看系统所有的进程数据
- ps ax # 查看不与terminal有关的所有进程
- ps -lA # 查看系统所有的进程数据
- ps axjf # 查看连同一部分进程树状态
- kill -signal PID
- 1:SIGHUP,启动被终止的进程
- 2:SIGINT,相当于输入ctrl+c,中断一个程序的进行
- 9:SIGKILL,强制中断一个进程的进行
- 15:SIGTERM,以正常的结束进程方式来终止进程
- 17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行
- # 以正常的结束进程方式来终于第一个后台工作,可用jobs命令查看后台中的第一个工作进程
- kill -SIGTERM %1
- # 重新改动进程ID为PID的进程,PID可用ps命令通过管道命令加上grep命令进行筛选获得
- kill -SIGHUP PID
- killall [-iIe] [command name]
- -i :交互式的意思,若需要删除时,会询问用户
- -e :表示后面接的command name要一致,但command name不能超过15个字符
- -I :命令名称忽略大小写
- # 例如:
- killall -SIGHUP syslogd # 重新启动syslogd
- file filename
- #例如:
- file ./test
- -c :新建打包文件
- -t :查看打包文件的内容含有哪些文件名
- -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
- -j :通过bzip2的支持进行压缩/解压缩
- -z :通过gzip的支持进行压缩/解压缩
- -v :在压缩/解压缩过程中,将正在处理的文件名显示出来
- -f filename :filename为要处理的文件
- -C dir :指定压缩/解压缩的目录dir
- 压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称
- 查询:tar -jtv -f filename.tar.bz2
- 解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录
- cat text | less # 查看text文件中的内容
- # 注:这条命令也可以使用less text来代替
- chgrp [-R] dirname/filename
- -R :进行递归的持续对所有文件和子目录更改
- # 例如:
- chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users
- chmod [-R] xyz 文件或目录
- -R:进行递归的持续更改,即连同子目录下的所有文件都会更改
- # 例如:
- chmod 0755 file # 把file的文件权限改变为-rxwr-xr-x
- chmod g+w file # 向file的文件权限中加入用户组可写权限
- -o :output之意,用于指定生成一个可执行文件的文件名
- -c :用于把源文件生成目标文件(.o),并阻止编译器创建一个完整的程序
- -I :增加编译时搜索头文件的路径
- -L :增加编译时搜索静态连接库的路径
- -S :把源文件生成汇编代码文件
- -lm:表示标准库的目录中名为libm.a的函数库
- -lpthread :连接NPTL实现的线程库
- -std= :用于指定把使用的C语言的版本
- # 例如:
- # 把源文件test.c按照c99标准编译成可执行程序test
- gcc -o test test.c -lm -std=c99
- #把源文件test.c转换为相应的汇编程序源文件test.s
- gcc -S test.c
- time ./process
- time ps aux
1.ls [选项] [目录名 | 列出相关目录下的所有目录和文件
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
-a 列出包括.a开头的隐藏文件的所有文件-A 通-a,但不列出"."和".."-l 列出文件的详细信息-c 根据ctime排序显示-t 根据文件修改时间排序---color[=WHEN] 用色彩辨别文件类型 WHEN 可以是’never’、’always’或’auto’其中之一白色:表示普通文件蓝色:表示目录绿色:表示可执行文件红色:表示压缩文件浅蓝色:链接文件红色闪烁:表示链接的文件有问题黄色:表示设备文件灰色:表示其它文件 |
2.mv [选项] 源文件或目录 目录或多个源文件 | 移动或重命名文件
|
1
2
3
4
5
6
7
8
9
|
-b 覆盖前做备份-f 如存在不询问而强制覆盖-i 如存在则询问是否覆盖-u 较新才覆盖-t 将多个源文件移动到统一目录下,目录参数在前,文件参数在后eg: mv a /tmp/ 将文件a移动到 /tmp目录下 mv a b 将a命名为b mv /home/zenghao test1.txt test2.txt test3.txt |
3.cp [选项] 源文件或目录 目录或多个源文件 | 将源文件复制至目标文件,或将多个源文件复制至目标目录。
|
1
2
3
4
5
|
-r -R 递归复制该目录及其子目录内容-p 连同档案属性一起复制过去-f 不询问而强制复制-s 生成快捷方式-a 将档案的所有特性都一起复制 |
4.scp [参数] [原路径] [目标路径] | 在Linux服务器之间复制文件和目录
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
-v 详细显示输出的具体情况-r 递归复制整个目录(1) 复制文件: 命令格式: scp local_file remote_username@remote_ip:remote_folder 或者 scp local_file remote_username@remote_ip:remote_file 或者 scp local_file remote_ip:remote_folder 或者 scp local_file remote_ip:remote_file 第1,2个指定了用户名,命令执行后需要输入用户密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名 第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名 (2) 复制目录: 命令格式: scp -r local_folder remote_username@remote_ip:remote_folder 或者 scp -r local_folder remote_ip:remote_folder 第1个指定了用户名,命令执行后需要输入用户密码; 第2个没有指定用户名,命令执行后需要输入用户名和密码;eg: 从 本地 复制到 远程 scp /home/daisy/full.tar.gz root@172.19.2.75:/home/root 从 远程 复制到 本地 scp root@/172.19.2.75:/home/root/full.tar.gz /home/daisy/full.tar.gz |
5.rm [选项] 文件 | 删除文件
|
1
2
3
4
|
-r 删除文件夹-f 删除不提示-i 删除提示-v 详细显示进行步骤 |
6.touch [选项] 文件 | 创建空文件或更新文件时间
|
1
2
3
4
5
|
-a 只修改存取时间-m 值修改变动时间-r eg:touch -r a b ,使b的时间和a相同-t 指定特定的时间 eg:touch -t 201211142234.50 log.log-t time [[CC]YY]MMDDhhmm[.SS],C:年前两位 |
7.pwd 查看当前所在路径
8.cd 改变当前目录
|
1
2
3
4
|
- :返回上层目录.. :返回上层目录回车 :返回主目录/ :根目录 |
9.mkdir [选项] 目录… | 创建新目录
|
1
2
3
4
5
6
|
-p 递归创建目录,若父目录不存在则依次创建-m 自定义创建目录的权限 eg:mkdir -m 777 hehe-v 显示创建目录的详细信息10.rmdir 删除空目录-v 显示执行过程-p 若自父母删除后父目录为空则一并删除 |
11.rm [选项] 文件… | 一个或多个文件或目录
|
1
2
3
4
|
-f 忽略不存在的文件,不给出提示-i 交互式删除-r 将列出的目录及其子目录递归删除-v 列出详细信息 |
12.echo:显示内容
|
1
2
3
4
5
|
n 输出后不换行-e 遇到转义字符特殊处理 eg: echo "he\nhe" 显示he\nhe ehco -e "he\nhe" 显示he(换行了)he |
13.cat [选项] [文件]..| 一次显示整个文件或从键盘创建一个文件或将几个文件合并成一个文件
|
1
2
|
-n 编号文件内容再输出-E 在结束行提示$ |
14.tac | 反向显示
15.more | 按页查看文章内容,从前向后读取文件,因此在启动时就加载整个文件
|
1
2
3
4
5
|
+n 从第n行开始显示-n 每次查看n行数据+/String 搜寻String字符串位置,从其前两行开始查看-c 清屏再显示-p 换页时清屏 |
16.less | 可前后移动地逐屏查看文章内容,在查看前不会加载整个文件
|
1
2
3
4
5
6
7
8
|
-m 显示类似于more命令的百分比-N 显示行号/ 字符串:向下搜索“字符串”的功能? 字符串:向上搜索“字符串”的功能n 重复前一个搜索(与 / 或 ? 有关)N 反向重复前一个搜索(与 / 或 ? 有关)b 向后翻一页d 向后翻半页 |
17.nl [选项]… [文件]… | 将输出内容自动加上行号
|
1
2
3
4
|
-b-b a 不论是否有空行,都列出行号(类似 cat -n)-b t 空行则不列行号(默认)-n 有ln rn rz三个参数,分别为再最左方显示,最右方显示不加0,最右方显示加0 |
18.head [参数]… [文件]… | 显示档案开头,默认开头10行
|
1
2
3
4
|
-v 显示文件名-c number 显示前number个字符,若number为负数,则显示除最后number个字符的所有内容-number/n (+)number 显示前number行内容,-n number 若number为负数,则显示除最后number行数据的所有内容 |
19.tail [必要参数] [选择参数] [文件] | 显示文件结尾内容
|
1
2
3
4
5
6
|
-v 显示详细的处理信息-q 不显示处理信息-num/-n (-)num 显示最后num行内容-n +num 从第num行开始显示后面的数据-c 显示最后c个字符-f 循环读取 |
20.vi 编辑文件
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
:w filename 将文章以指定的文件名保存起来 :wq 保存并退出:q! 不保存而强制退出命令行模式功能键1)插入模式 按「i」切换进入插入模式「insert mode」,按"i"进入插入模式后是从光标当前位置开始输入文件; 按「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字; 按「o」进入插入模式后,是插入新的一行,从行首开始输入文字。2)从插入模式切换为命令行模式 按「ESC」键。3)移动光标 vi可以直接用键盘上的光标来上下左右移动,但正规的vi是用小写英文字母「h」、「j」、「k」、「l」,分别控制光标左、下、上、右移一格。 按「ctrl」+「b」:屏幕往"后"移动一页。 按「ctrl」+「f」:屏幕往"前"移动一页。 按「ctrl」+「u」:屏幕往"后"移动半页。 按「ctrl」+「d」:屏幕往"前"移动半页。 按数字「0」:移到文章的开头。 按「G」:移动到文章的最后。 按「$」:移动到光标所在行的"行尾"。 按「^」:移动到光标所在行的"行首" 按「w」:光标跳到下个字的开头 按「e」:光标跳到下个字的字尾 按「b」:光标回到上个字的开头 按「#l」:光标移到该行的第#个位置,如:5l,56l。4)删除文字 「x」:每按一次,删除光标所在位置的"后面"一个字符。 「#x」:例如,「6x」表示删除光标所在位置的"后面"6个字符。 「X」:大写的X,每按一次,删除光标所在位置的"前面"一个字符。 「#X」:例如,「20X」表示删除光标所在位置的"前面"20个字符。 「dd」:删除光标所在行。 「#dd」:从光标所在行开始删除#行5)复制 「yw」:将光标所在之处到字尾的字符复制到缓冲区中。 「#yw」:复制#个字到缓冲区 「yy」:复制光标所在行到缓冲区。 「#yy」:例如,「6yy」表示拷贝从光标所在的该行"往下数"6行文字。 「p」:将缓冲区内的字符贴到光标所在位置。注意:所有与"y"有关的复制命令都必须与"p"配合才能完成复制与粘贴功能。6)替换 「r」:替换光标所在处的字符。 「R」:替换光标所到之处的字符,直到按下「ESC」键为止。7)回复上一次操作 「u」:如果您误执行一个命令,可以马上按下「u」,回到上一个操作。按多次"u"可以执行多次回复。8)更改 「cw」:更改光标所在处的字到字尾处 「c#w」:例如,「c3w」表示更改3个字9)跳至指定的行 「ctrl」+「g」列出光标所在行的行号。 「#G」:例如,「15G」,表示移动光标至文章的第15行行首。 |
21.which 可执行文件名称 | 查看可执行文件的位置,在PATH变量指定的路径中查看系统命令是否存在及其位置
22.whereis [-bmsu] [BMS 目录名 -f ] 文件名| 定位可执行文件、源代码文件、帮助文件在文件系统中的位置
|
1
2
3
4
5
6
7
|
-b 定位可执行文件。-m 定位帮助文件。-s 定位源代码文件。-u 搜索默认路径下除可执行文件、源代码文件、帮助文件以外的其它文件。-B 指定搜索可执行文件的路径。-M 指定搜索帮助文件的路径。-S 指定搜索源代码文件的路径。 |
23.locate | 通过搜寻数据库快速搜寻档案
-r 使用正规运算式做寻找的条件
24.find find [PATH] [option] [action] | 在文件树种查找文件,并作出相应的处理
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
选项与参数:1. 与时间有关的选项:共有 -atime, -ctime 与 -mtime 和-amin,-cmin与-mmin,以 -mtime 说明 -mtime n :n 为数字,意义为在 n 天之前的『一天之内』被更动过内容的档案; -mtime +n :列出在 n 天之前(不含 n 天本身)被更动过内容的档案档名; -mtime -n :列出在 n 天之内(含 n 天本身)被更动过内容的档案档名。 -newer file :file 为一个存在的档案,列出比 file 还要新的档案档名2. 与使用者或组名有关的参数: -uid n :n 为数字,这个数字是用户的账号 ID,亦即 UID -gid n :n 为数字,这个数字是组名的 ID,亦即 GID -user name :name 为使用者账号名称!例如 dmtsai -group name:name 为组名,例如 users ; -nouser :寻找档案的拥有者不存在 /etc/passwd 的人! -nogroup :寻找档案的拥有群组不存在于 /etc/group 的档案!3. 与档案权限及名称有关的参数: -name filename:搜寻文件名为 filename 的档案(可使用通配符) -size [+-]SIZE:搜寻比 SIZE 还要大(+)或小(-)的档案。这个 SIZE 的规格有: c: 代表 byte k: 代表 1024bytes。所以,要找比 50KB还要大的档案,就是『 -size +50k 』 -type TYPE :搜寻档案的类型为 TYPE 的,类型主要有: 一般正规档案 (f) 装置档案 (b, c) 目录 (d) 连结档 (l) socket (s) FIFO (p) -perm mode :搜寻档案权限『刚好等于』 mode的档案,这个mode为类似chmod的属性值,举例来说,-rwsr-xr-x 的属性为4755! -perm -mode :搜寻档案权限『必须要全部囊括 mode 的权限』的档案,举例来说, 我们要搜寻-rwxr--r-- 亦即 0744 的档案,使用-perm -0744,当一个档案的权限为 -rwsr-xr-x ,亦即 4755 时,也会被列出来,因为 -rwsr-xr-x 的属性已经囊括了 -rwxr--r-- 的属性了。 -perm +mode :搜寻档案权限『包含任一 mode 的权限』的档案,举例来 说,我们搜寻-rwxr-xr-x ,亦即 -perm +755 时,但一个文件属性为 -rw-------也会被列出来,因为他有 -rw.... 的属性存在!4. 额外可进行的动作: -exec command :command 为其他指令,-exec 后面可再接额外的指令来处理搜寻到的结果。 -print :将结果打印到屏幕上,这个动作是预设动作! eg: find / -perm +7000 -exec ls -l {} \; ,额外指令以-exec开头,以\;结尾{}代替前面找到的内容 | xargs -i 默认的前面输出用{}代替 eg: find . -name "*.log" | xargs -i mv {} test4 |
25.file | 判断文件类型
26.gzip [-cdtv#] 檔名 | 压缩、解压缩,源文件都不再存在
|
1
2
3
4
|
-d 进行解压缩-c 将压缩的数据输出到屏幕上-v :显示原档案/压缩文件案的压缩比等信息-# :压缩等级,-1最快,但压缩比最差,=9最慢,但压缩比最好 |
27.gunzip | 解压缩
28.bzip2 | 压缩、解压缩
|
1
2
3
4
5
6
|
-d :解压-z :压缩-k :保留源文件-c :将压缩的过程产生的数据输出到屏幕上!-v :可以显示出原档案/压缩文件案的压缩比等信息;-# :与 gzip 同样的,都是在计算压缩比的参数, -9 最佳, -1 最快! |
29.bzcat 读取数据而无需解压
30.tar [主选项+辅选项] 文件或者目录 | 多个目录或档案打包、压缩成一个大档案
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
主选项: -c 建立打包档案,可搭配 -v 来察看过程中被打包的档名(filename) -t 察看打包档案的内容含有哪些档名,重点在察看『档名』就是了; -x 解打包或解压缩的功能,可以搭配 -C (大写) 在特定目录解开辅选项: -j 透过 bzip2 的支持进行压缩/解压缩:此时档名最好为 *.tar.bz2 -z 透过 gzip 的支持进行压缩/解压缩:此时档名最好为 *.tar.gz -v 在压缩/解压缩的过程中,将正在处理的文件名显示出来! -f filename -f 后面要立刻接要被处理的档名! -C 目录 这个选项用在解压缩,若要在特定目录解压缩,可以使用这个选项。 --exclude FILE:在压缩打包过程中忽略某文件 eg: tar --exclude /home/zenghao -zcvf myfile.tar.gz /home/* /etc -p 保留备份数据的原本权限与属性,常用于备份(-c)重要的配置文件 -P(大写) 保留绝对路径,亦即允许备份数据中含有根目录存在之意;eg: 压 缩:tar -jcvf filename.tar.bz2 要被压缩的档案或目录名称 查 询:tar -jtvf filename.tar.bz2 解压缩:tar -jxvf filename.tar.bz2 -C 欲解压缩的目录 |
31.exit 退出当前shell
32.logout 退出登录shell
33.shutdown -h now
34.users 显示当前登录系统地用户
35.who 登录在本机的用户与来源
|
1
|
-H或--heading 显示各栏位的标题信息列。 |
36.w 登录在本机的用户及其运行的程序
|
1
2
|
-s 使用简洁格式列表,不显示用户登入时间,终端机阶段作业和程序所耗费的CPU时间。-h 不显示各栏位的标题信息列。 |
37.write 给当前联机的用户发消息
38.wall 给所有登录再本机的用户发消息
39.last 查看用户的登陆日志
40.lastlog 查看每个用户最后的登陆时间
41.finger [选项] [使用者] [用户@主机] | 查看用户信息
|
1
2
3
|
-s 显示用户的注册名、实际姓名、终端名称、写状态、停滞时间、登录时间等信息-l 除了用-s选项显示的信息外,还显示用户主目录、登录shell、邮件状态等信息,以及用户主目录下的.plan、.project和.forward文件的内容。-p 除了不显示.plan文件和.project文件以外,与-l选项相同 |
42.hostname 查看主机名
43.alias ii = “ls -l” | 添加别名
44.unalias ii | 清除别名
45.useradd [-u UID] [-g 初始群组] [-G 次要群组] [-c 说明栏] [-d 家目录绝对路径] [-s shell] 使用者账号名 | 新增用户
|
1
2
3
4
5
|
-M 不建立用户家目录!(系统账号默认值)-m 建立用户家目录!(一般账号默认值)-r 建立一个系统的账号,这个账号的 UID 会有限制-e 账号失效日期,格式为『YYYY-MM-DD』-D 查看useradd的各项默认值 |
46.passwd | 修改密码
|
1
2
3
4
5
6
7
8
|
-l 使密码失效-u 与-l相对,用户解锁-S 列出登陆用户passwd文件内的相关参数-n 后面接天数,shadow 的第 4 字段,多久不可修改密码天数-x 后面接天数,shadow 的第 5 字段,多久内必须要更动密码-w 后面接天数,shadow 的第 6 字段,密码过期前的警告天数-i 后面接『日期』,shadow 的第 7 字段,密码失效日期使用管道刘设置密码:echo "zeng" | passwd --stdin zenghao |
47.userdel 删除用户
|
1
|
-r 用户文件一并删除 |
48.chage [-ldEImMW] 账号名 | 修改用户密码的相关属性
|
1
2
3
4
5
6
7
|
-l 列出该账号的详细密码参数;-d 后面接日期,修改 shadow 第三字段(最近一次更改密码的日期),格式YYYY-MM-DD-E 后面接日期,修改 shadow 第八字段(账号失效日),格式 YYYY-MM-DD-I 后面接天数,修改 shadow 第七字段(密码失效日期)-m 后面接天数,修改 shadow 第四字段(密码最短保留天数)-M 后面接天数,修改 shadow 第五字段(密码多久需要进行变更)-W 后面接天数,修改 shadow 第六字段(密码过期前警告日期) |
49.usermod [-cdegGlsuLU] username | 修改用户的相关属性
|
1
2
3
4
5
6
7
8
9
10
11
|
-c 后面接账号的说明,即 /etc/passwd 第五栏的说明栏,可以加入一些账号的说明。-d 后面接账号的家目录,即修改 /etc/passwd 的第六栏;-e 后面接日期,格式是 YYYY-MM-DD 也就是在 /etc/shadow 内的第八个字段数据啦!-f 后面接天数为 shadow 的第七字段。-g 后面接初始群组,修改 /etc/passwd 的第四个字段,亦即是GID的字段!-G 后面接次要群组,修改这个使用者能够支持的群组-l 后面接账号名称。亦即是修改账号名称, /etc/passwd 的第一栏!-s 后面接 Shell 的实际档案,例如 /bin/bash 或 /bin/csh 等等。-u 后面接 UID 数字啦!即 /etc/passwd 第三栏的资料;-L 冻结密码-U 解冻密码 |
50.id [username] | 查看用户相关的id信息,还可以用来判断用户是否存在
51.groups 查看登陆用户支持的群组, 第一个输出的群组为有效群组
52.newgrp 切换有效群组
53.groupadd [-g gid] 组名 | 添加组
|
1
|
-g 设定添加组的特定组id |
54.groupmod [-g gid] [-n group_name] 群组名 | 修改组信息
|
1
2
|
-g 修改既有的 GID 数字-n 修改既有的组名 |
55.groupdel [groupname] | 删除群组
56.gpasswd | 群组管理员功能
|
1
2
3
4
5
6
7
8
9
10
11
|
root管理员动作: -gpasswd groupname 设定密码 -gpasswd [-A user1,...] [-M user3,...] groupname -A 将 groupname 的主控权交由后面的使用者管理(该群组的管理员) -M 将某些账号加入这个群组当中 -gpasswd [-r] groupname -r 将 groupname 的密码移除群组管理员动作: - gpasswd [-ad] user groupname -a 将某位使用者加入到 groupname 这个群组当中 -d 将某位使用者移除出 groupname 这个群组当中 |
57.chfn修改个人信息
58.mount [-t vfstype] [-o options] device dir
|
1
2
3
|
-ro 采用只读方式挂接设备-rw 采用读写方式挂接设备eg:mount /home/mydisk.iso /tmp/mnt 通过mnt访问mydisk内的内容 |
59.umount 取消挂载
60.cut
|
1
2
3
4
|
-b :以字节为单位进行分割。这些字节位置将忽略多字节字符边界,除非也指定了 -n 标志。-c :以字符为单位进行分割。-d :自定义分隔符,默认为制表符。-f :与-d一起使用,指定显示哪个区域。 |
61.sort
|
1
2
3
4
5
|
-n 依照数值的大小排序。-o<输出文件> 将排序后的结果存入指定的文件。-r 以相反的顺序来排序。-t<分隔字符> 指定排序时所用的栏位分隔字符。-k 选择以哪个区间进行排序。 |
62.wc 统计指定文件中的字节数、字数、行数, 并将统计结果显示输出
|
1
2
3
4
|
-l filename 报告行数-c filename 报告字节数-m filename 报告字符数-w filename 报告单词数 |
63.uniq 去除文件中相邻的重复行
|
1
2
3
|
清空/新建文件,将内容重定向输入进去&> 正确、错误都重定向过去后面追加 |
64.set 显示环境变量和普通变量
65.env 显示环境变量
66.export 把普通变量变成环境变量
67.unset 删除一个环境变量
|
1
|
aaa(){} 定义函数 |
68.read
|
1
2
|
-p 接提示字符-t 接等待的秒数 |
69.declare、typeset
|
1
2
3
4
|
-i 声明为整数-a 声明为数组-f 声明为函数-r 声明为只读 |
70.ulimit 限制使用者的某些系统资源
|
1
2
|
-f 此 shell 可以建立的最大档案容量 (一般可能设定为 2GB)单位为 Kbytes eg: ulimit -f 1024限制使用者仅能建立 1MBytes 以下的容量的档案 |
71.df [选项] [文件] | 显示指定磁盘文件的可用空间,如果没有文件名被指定,则所有当前被挂载的文件系统的可用空间将被显示
|
1
2
3
4
5
|
-a 显示全部文件系统-h 文件大小友好显示-l 只显示本地文件系统-i 显示inode信息-T 显示文件系统类型 |
72.du [选项] [文件] | 显示每个文件和目录的磁盘使用空间
|
1
2
|
-h 方便阅读的方式-s 只显示总和的大小 |
73.ln [参数] [源文件或目录] [目标文件或目录] | 某一个文件在另外一个位置建立一个同步的链接
|
1
2
|
-s 建立软连接-v 显示详细的处理过程 |
74.diff [参数] [文件1或目录1] [文件2或目录2] | 比较单个文件或者目录内容
|
1
2
3
4
5
|
-b 不检查空格字符的不同。-B 不检查空白行。-i 不检查大小写-q 仅显示差异而不显示详细信息eg: diff a b > parch.log 比较两个文件的不同并产生补丁 |
75.date [参数]… [+格式] | 显示或设定系统的日期与时间
|
1
2
3
4
5
6
7
8
9
10
|
%H 小时(以00-23来表示)。%M 分钟(以00-59来表示)。%P AM或PM。%D 日期(含年月日)%U 该年中的周数。date -s “2015-10-17 01:01:01″ //时间设定date +%Y%m%d //显示前天年月日date +%Y%m%d --date="+1 day/month/year" //显示前一天/月/年的日期date +%Y%m%d --date="-1 day/month/year" //显示后一天/月/年的日期date -d '2 weeks' 2周后的日期 |
76.cal [参数] 月份] [年份] | 查看日历
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
-1 显示当月的月历-3 显示前、当、后一个月的日历-m 显示星期一为一个星期的第一天-s (默认)星期天为第一天-j 显示当月是一年中的第几天的日历-y 显示当前年份的日历77.ps | 列出当前进程的快照a 显示所有的进程-a 显示同一终端下的所有程序e 显示环境变量f 显示进程间的关系-H 显示树状结构r 显示当前终端的程序T 显示当前终端的所有程序-au 显示更详细的信息-aux 显示所有包含其他使用者的行程-u 指定用户的所有进程 |
78.top [参数] | 显示当前系统正在执行的进程的相关信息,包括进程ID、内存占用率、CPU占用率等
79.kill [参数] [进程号] | 杀死进程
80.free [参数] | 显示Linux系统中空闲的、已用的物理内存及swap内存,及被内核使用的buffer
81.vmstat | 对操作系统的虚拟内存、进程、CPU活动进行监控
82.iostat [参数] [时间t] [次数n](每隔t时间刷新一次,最多刷新n次)| 对系统的磁盘操作活动进行监视,汇报磁盘活动统计情况,同时也会汇报出CPU使用情况
|
1
|
-p[磁盘] 显示磁盘和分区的情况 |
83.watch [参数] [命令] |重复执行某一命令以观察变化
|
1
2
|
-n 时隔多少秒刷新-d 高亮显示动态变化 |
84.at [参数] [时间] | 在一个指定的时间执行一个指定任务,只能执行一次
|
1
2
3
4
|
HH:MM[am|pm] + number [minutes|hours|days|weeks] 强制在某年某月某日的某时刻进行该项任务atq 查看系统未执行的任务atrm n 删除编号为n的任务at -c n 显示编号为n的任务的内容 |
85.crontab | 定时任务调度
|
1
2
3
4
|
file 载入crontab-e 编辑某个用户的crontab文件内容-l 显示某个用户的crontab文件内容-r 删除某个用户的crontab文件 |
86.ifconfig [网络设备] [参数] | 查看和配置网络设备
87.route | 显示和操作IP路由表
88.ping [参数] [主机名或IP地址] | 测试与目标主机的连通性
|
1
|
-q 只显示最后的结果 |
89.netstat | 显示与IP、TCP、UDP和ICMP协议相关的统计数据
90.telnet [参数] [主机] | 用于远程登录,采用明文传送报文,安全性不好
91.rcp [参数] [源文件] [目标文件] | 远程文件拷贝
|
1
2
3
|
-r 递归复制-p 保留源文件的属性usage: rcp –r remote_hostname:remote_dir local_dir |
92.wget [参数] [URL地址] | 直接从网络上下载文件
|
1
2
|
-o FILE 把记录写到FILE文件中 eg : wget -O a.txt URLwget --limit-rate=300k URL 限速下载 |
93.awk
|
1
2
|
-F 分隔符 以分隔符分隔内容{} 要执行的脚本内容 eg:cat /etc/passwd |awk -F ':' '{print $1"\t"$7}' |
94.sed 对数据行进行替换、删除、新增、选取等操作
|
1
2
3
4
|
a 新增,在新的下一行出现c 取代,取代 n1,n2 之间的行 eg: sed '1,2c Hi' abd 删除i 插入,在新的上一行出现 |
95.paste 合并文件,需确保合并的两文件行数相同
|
1
2
|
-d 指定不同于空格或tab键的域分隔符-s 按行合并,单独一个文件为一行 |
96.su [参数] user | 切换登陆
|
1
2
|
-l 切换时连同环境变量、工作目录一起改变-c command 执行command变回原来的使用者 |
97.sudo | 以特定用户的权限执行特定命令
|
1
2
|
-l 列出当前用户可执行的命令-u username#uid 以指定用户执行命令 |

浙公网安备 33010602011771号