linux命令---常⽤组合
1. 输出当前系统中占⽤内存最多的5条命令:
#1) 通过ps命令列出当前主机正在运⾏的所有进程。
#2) 按照第五个字段基于数值的形式进⾏正常排序(由⼩到⼤)。
#3) 仅显⽰最后5条输出。
/> ps aux | sort -k 5n | tail -5
stephen 1861 0.2 2.0 96972 21596 ? S Nov11 2:24 nautilus
stephen 1892 0.0 0.4 102108 4508 ? S<sl Nov11 0:00 /usr/bin/pulseaudio
stephen 1874 0.0 0.9 107648 10124 ? S Nov11 0:00 gnome-volume
stephen 1855 0.0 1.2 123776 13112 ? Sl Nov11 0:00 metacity
stephen 1831 0.0 0.9 125432 9768 ? Ssl Nov11 0:05 /usr/libexec/gnome
2. 出cpu利⽤率⾼的20个进程:
#1) 通过ps命令输出所有进程的数据,-o选项后⾯的字段列表列出了结果中需要包含的数据列。
#2) 将ps输出的Title⾏去掉,grep -v PID表⽰不包含PID的⾏。
#3) 基于第⼀个域字段排序,即pcpu。n表⽰以数值的形式排序。
#4) 输出按cpu使⽤率排序后的最后20⾏,即占⽤率最⾼的20⾏。
/> ps -e -o pcpu,pid,user,sgi_p,cmd | grep -v PID | sort -k 1n | tail -20
3. 获取当前系统物理内存的总⼤⼩:
#1) 以兆(MB)为单位输出系统当前的内存使⽤状况。
#2) 通过grep定位到Mem⾏,该⾏是以操作系统为视⾓统计数据的。
#3) 通过awk打印出该⾏的第⼆列,即total列。
/> free -m | grep "Mem" | awk '{print $2, "MB"}'
1007 MB
⼆⼗⼀. 通过管道组合Shell命令进⾏系统管理:
1. 获取当前或指定⽬录下⼦⽬录所占⽤的磁盘空间,并将结果按照从⼤到⼩的顺序输出:
#1) 输出/usr的⼦⽬录所占⽤的磁盘空间。
#2) 以数值的⽅式倒排后输出。
/> du -s /usr/* | sort -nr
1443980 /usr/share
793260 /usr/lib
217584 /usr/bin
128624 /usr/include
60748 /usr/libexec
45148 /usr/src
21096 /usr/sbin
6896 /usr/local
4 /usr/games
4 /usr/etc
0 /usr/tmp
2. 批量修改⽂件名:
#1) find命令到⽂件名扩展名为.output的⽂件。
#2) sed命令中的-e选项表⽰流编辑动作有多次,第⼀次是将到的⽂件名中相对路径前缀部分去掉,如./aa改为aa。 # 流编辑的第⼆部分,是将20110311替换为mv & 20110310,其中&表⽰s命令的被替换部分,这⾥即源⽂件名。 # \1表⽰被替换部分中#的\(.*\)。
#3) 此时的输出应为
# mv 20110311.output 20110310.output
# mv 20110311abc.output 20110310abc.output
# 最后将上⾯的输出作为命令交给bash命令去执⾏,从⽽将所有20110311*.output改为20110311*.output
/> find ./ -name "*.output" -print | sed -e 's/.\///g' -e 's/20110311\(.*\)/mv & 20110310\1/g' | bash
3. 统计当前⽬录下⽂件和⽬录的数量:
#1) ls -l命令列出⽂件和⽬录的详细信息。
#2) ls -l输出的详细列表中的第⼀个域字段是⽂件或⽬录的权限属性部分,如果权限属性部分的第⼀个字符为d,
# 该⽂件为⽬录,如果是-,该⽂件为普通⽂件。
#3) 通过wc计算grep过滤后的⾏数。
/> ls -l * | grep "^-" | wc -l
/> ls -l * | grep "^d" | wc -l
linux所有命令都无法使用4. 杀掉指定终端的所有进程:
#1) 通过ps命令输出终端为pts/1的所有进程。
#2) 将ps的输出传给grep,grep将过滤掉ps输出的Title部分,-v PID表⽰不包含PID的⾏。 #3) awk打印输出grep查结果的第⼀个字段,即pid字段。
#4) 上⾯的三个组合命令是在反引号内被执⾏的,并将执⾏的结果赋值给数组变量${K}。 #5) kill⽅法将杀掉数组${K}包含的pid。
/> kill -9 ${K}=`ps -t pts/1 | grep -v PID | awk '{print $1}'`
5. 将查到的⽂件打包并copy到指定⽬录:
#1) 通过find到当前⽬录下(包含所有⼦⽬录)的所有*.txt⽂件。
#2) tar命令将find到的结果压缩成test.tar压缩包⽂件。
#3) 如果&&左侧括号内的命令正常完成,则可以执⾏&&右侧的shell命令了。
#4) 将⽣成后的test.tar⽂件copy到/home/.⽬录下。
/> (find . -name "*.txt" | xargs tar -cvf test.tar) && cp -f test.tar /home/.
#1) cpio从find的结果中读取⽂件名,将其打包压缩后发送到./dest/dir(⽬标⽬录)。
#2) cpio的选项介绍:
# -d:创建需要的⽬录。
# -a:重置源⽂件的访问时间。
# -m:保护新⽂件的修改时间。
# -p:将cpio设置为copy pass-through模式。
/> find . -name "*" | cpio -dampv ./dest/dir
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论