周天奋战一天Linux Shell经常使用技巧(十)

 

 

 

 

  须要说明的是,该篇Blog中绝大多数的示例来自于互联网,是本人通过一天左右的时间收集和整理以后筛选出来的,其中注释部分是我在后来添加的,以便于咱们阅读时的理解。若是从此再发现更好更巧妙的Shell组合命令,本人将持续更新该Blog。若是您有确实很是不错的Shell命令组合,且愿意和咱们在这里分享,能够直接放在回复中,本人将对该篇Blog始终保持重点关注。更多linux架构干货资料领取地址:812855908linux

经过管道组合Shell命令获取系统运行数据:shell

    1. 输出当前系统中占用内存最多的5条命令:数组

   #1) 经过ps命令列出当前主机正在运行的全部进程。bash

   #2) 按照第五个字段基于数值的形式进行正常排序(由小到大)。架构

   #3) 仅显示最后5条输出。操作系统

    /> ps aux | sort -k 5n | tail -5blog

   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

    

   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

相关文章
相关标签/搜索