当前位置: 首页 > 工具软件 > Piping > 使用案例 >

进程管道 Piping

段干华晖
2023-12-01

 

进程管道 Piping


====================================================================================
• Use redirection characters to control output to files.
• Use piping to control outputto other programs.

files: > 2> file1.txt /dev/pts/2 /dev/tty1/dev/null /dev/sda
programs: |

进程管道
用法:command1 | command2|command3 |...


[root@tianyun ~]# ll /dev/ |less
[root@tianyun ~]# ps aux |grep 'sshd'
[root@tianyun ~]# rpm -qa |grep 'httpd' //查询所有安装的软件包,过滤包含httpd的包
[root@tianyun ~]# yum list |grep 'httpd'

案例1:将/etc/passwd中的用户按UID大小排序
[root@tianyun ~]# sort -t":" -k3 -n /etc/passwd //以: 分隔,将第三列按字数升序
[root@tianyun ~]# sort -t":" -k3 -n /etc/passwd -r //逆序
[root@tianyun ~]# sort -t":" -k3 -n /etc/passwd |head
-t 指定字段分隔符--field-separator
-k 指定列
-n 按数值

案例2:统计出最占CPU的5个进程
[root@tianyun ~]# ps aux --sort=-%cpu |head -6

案例3:统计当前/etc/passwd中用户使用的shell类型
思路:取出第七列(shell) | 排序(把相同归类)| 去重
[root@tianyun ~]# awk -F: '{print $7}' /etc/passwd
[root@tianyun ~]# awk -F: '{print $7}' /etc/passwd |sort
[root@tianyun ~]# awk -F: '{print $7}' /etc/passwd |sort |uniq
[root@tianyun ~]# awk -F: '{print $7}' /etc/passwd |sort |uniq -c
131 /bin/bash
1 /bin/sync
1 /sbin/halt
63 /sbin/nologin
1 /sbin/shutdown
-F: 指定字段分隔符
$7
第七个字段

案例4: 统计网站的访问情况 top 20
思路: 打印所有访问的连接 | 过滤访问网站的连接 | 打印用户的IP | 排序| 去重
[root@tianyun ~]# ss -an |grep :80 |awk -F":" '{print $8}' |sort|uniq -c
4334 192.168.0.66
1338 192.168.10.11
1482 192.168.10.125
44 192.168.10.183
3035 192.168.10.213
375 192.168.10.35
362 192.168.10.39
[root@tianyun ~]# ss -an |grep :80 |awk -F":" '{print $8}' |sort|uniq -c |sort -k1 -rn |head -n 20

案例5: 打印当前所有IP
[root@tianyun ~]# ip addr |grep 'inet ' |awk '{print $2}' |awk -F"/"'{print $1}'
127.0.0.1
192.168.2.115

案例6:打印根分区已用空间的百分比(仅打印数字)
[root@tianyun ~]# df -P |grep '/$' |awk '{print $5}' |awk -F"%"'{print $1}'


tee管道

[root@tianyun ~]# ip addr |grep 'inet ' |teeip.txt |awk -F"/" '{print $1}' |awk '{print $2}'
127.0.0.1
172.16.60.1
[root@tianyun ~]# cat ip.txt
inet 127.0.0.1/8 scope host lo
inet 172.16.60.1/24 brd 172.16.60.255 scope global eth0


[root@tianyun ~]# ip addr |grep 'inet ' |tee -a ip.txt |awk -F"/" '{print $1}'|awk '{print $2}'
127.0.0.1
172.16.60.1

[root@tianyun ~]# date |tee date.txt
Sat Mar 11 10:22:31 CST 2017





 

 

 

 类似资料: