Linux命令输出头(标题)、输出结果排序技巧
原⽂:
--------------------------------------------------------
1、 Linux命令输出头(标题)
在使⽤Linux命令时,如果命令中有管道“|”,则输出的信息中,头(标题)信息丢失,要想看每⼀列代表什么意思很不⽅便。
这⾥有⼀个简单的办法,通过2条命令叠加,获取头和内容。例如ps auxw:
$ ps axuw
USER      PID %CPU %MEM    VSZ  RSS TTY      STAT START  TIME COMMAND
root        1  0.0  0.2  37888  5952 ?        Ss  01:21  0:02 /sbin/init noprompt
root        2  0.0  0.0      0    0 ?        S    01:21  0:00 [kthreadd]
root        3  0.0  0.0      0    0 ?        S    01:21  0:00 [ksoftirqd/0]
root        5  0.0  0.0      0    0 ?        S<  01:21  0:00 [kworker/0:0H]
再加上管道符后
$ ps axuw | grep java
faster    8502  0.0  0.0  12948  972 pts/1    S+  02:15  0:00 grep java
可以看到头(标题)已经丢失。
怎么显⽰标题呢,这有⼀个简单的办法:
$ ps axuw | head -1;ps axuw | grep java
USER      PID %CPU %MEM    VSZ  RSS TTY      STAT START  TIME COMMAND
faster    8510  0.0  0.0  12948  940 pts/1    S+  02:17  0:00 grep java
也就是先⽤命令本⾝加“| head -1”取到头(标题),然后再使⽤该命令输出内容,两者叠加输出即得到所要结果。
2、输出结果排序sort命令排序
按列排序,数字⼤的在前:
root@ubuntu:/home/faster/Fastdfs/FastDFS# ps auxw | sort -rn -k6
root      851  0.2  1.6 408816 33224 ?        Ssl  01:21  0:10 /usr/bin/docker daemon -H fd://
root      868  0.0  0.6 213068 13320 ?        Ssl  01:21  0:02 containerd -l /var/run/docker/libcontainerd/docker-containerd.sock --runtime runc --start-timeout 2m
root      8452  0.0  0.3  95584  7212 ?        Ss  01:47  0:00 sshd: tiger [priv]
root      980  0.0  0.3  95464  7088 ?        Ss  01:21  0:00 sshd: tiger [priv]
root      1044  0.0  0.3  95464  7048 ?        Ss  01:23  0:00 sshd: tiger [priv]
root      854  0.0  0.3  65612  6616 ?        Ss  01:21  0:00 /usr/sbin/sshd -D
root      592  0.0  0.3 274592  6240 ?        Ssl  01:21  0:00 /usr/lib/accountsservice/accou
该例⼦,将第6列进⾏排序,最⼤的数排前⾯。
若只想看前10条的内容:
ps auxw | sort -rn -k6 | head -10
3、综合例⼦
将实际内存消耗最⼤的10个进程显⽰出来的命令:
ps auxw|head -1;ps auxw|sort -rn -k6|head -10
$ ps auxw|head -1;ps auxw|sort -rn -k6|head -10
USER      PID %CPU %MEM    VSZ  RSS TTY      STAT START  TIME COMMAND
root      851  0.2  1.6 408816 33224 ?        Ssl  01:21  0:11 /usr/bin/docker daemon -H fd://
root      868  0.0  0.6 213068 13320 ?        Ssl  01:21  0:03 containerd -l /var/run/docker/libcontainerd/docker-containerd.sock --runtime runc
--start-timeout 2m
root      8452  0.0  0.3  95584  7212 ?        Ss  01:47  0:00 sshd: tiger [priv]
root      980  0.0  0.3  95464  7088 ?        Ss  01:21  0:00 sshd: tiger [priv]
root      1044  0.0  0.3  95464  7048 ?        Ss  01:23  0:00 sshd: tiger [priv]
root      854  0.0  0.3  65612  6616 ?        Ss  01:21  0:00 /usr/sbin/sshd -D
root      592  0.0  0.3 274592  6240 ?        Ssl  01:21  0:00 /usr/lib/accountsservice/accounts-daemon root        1  0.0  0.2  37888  5952 ?        Ss  01:21  0:02 /sbin/init noprompt
syslog    576  0.0  0.2 256396  5372 ?        Ssl  01:21  0:00 /usr/sbin/rsyslogd -n
faster    1137  0.0  0.2  21224  5272 pts/0    S    01:37  0:00 -su
该命令亦可使⽤ps auxw --sort=-rss|head -10命令替代。