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

15-进程管道Piping

宋高扬
2023-12-01

• Use redirection characters to control output to files.

• Use piping to control output to other programs.

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

进程管道

用法:command1 | command2 |command3 |

[root@fanhua ~]# ll /dev/ |less

[root@fanhua ~]# ps aux |grep 'sshd'

[root@fanhua ~]# rpm -qa |grep 'httpd' 	  //查询所有安装的软件包,过滤包含httpd的包

[root@fanhua ~]# yum list |grep 'httpd'

案例1:将/etc/passwd中的用户按UID大小排序

[root@fanhua ~]# cat a.txt 
1:h
2:h
3:h
4:h
5:h
6:h
7:h
8:h
9:h
10:h
[root@fanhua ~]# sort -t":" -k3 -n  a.txt		    //以: 分隔,将第三列按字数升序

[root@fanhua ~]# sort -t":" -k3 -n  a.txt -r   	    //-r  逆序 

[root@fanhua ~]# sort -t":" -k3 -n  a.txt |head 	//-t 指定字段分隔符 -k 指定列 -n 按数值

案例2:统计出最占CPU的5个进程

[root@fanhua ~]# ps aux --sort=-%cpu |head -6 

案例3:统计当前/etc/passwd中用户使用的shell类型

思路:取出第七列(shell) | 排序(把相同归类)| 去重

[root@fanhua ~]# awk -F: '{print $7}' /etc/passwd
[root@fanhua ~]# awk -F: '{print $7}' /etc/passwd |sort			//sort分类
[root@fanhua ~]# awk -F: '{print $7}' /etc/passwd |sort |uniq  //uniq去重
[root@fanhua ~]# awk -F: '{print $7}' /etc/passwd |sort |uniq -c   //去重并统计类别的数量
 40 /bin/bash
  1 /bin/sync
  1 /sbin/halt
 22 /sbin/nologin
  1 /sbin/shutdown

-F: 指定字段分隔符

$7 第七列字段

案例4: 统计网站的访问情况 top 20 思路: 打印所有访问的连接 | 过滤访问网站的连接 | 打印用户的IP | 排序 | 去重

[root@fanhua ~]# yum -y install httpd 

[root@fanhua ~]# systemctl start httpd

[root@fanhua ~]# systemctl stop firewalld

[root@fanhua ~]# 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@fanhua ~]# ss -an |grep :80 |awk -F":" '{print $8}' |sort |uniq -c |sort -k1 -rn |head -n 20

案例5: 打印当前所有IP

[root@fanhua ~]# ip addr |grep 'inet ' |awk '{print $2}' |awk -F"/" '{print $1}' 127.0.0.1 
192.168.2.115

案例6:打印根分区已用空间的百分比(仅打印数字)

[root@fanhua ~]# df -P |grep '/$' |awk '{print $5}' |awk -F"%" '{print $1}' 6

[root@fanhua ~]# df -Th|grep '/$' |awk '{print $6}' |awk -F"%" '{print $1}' 9
 



[root@fanhua ~]# ip addr |grep 'inet ' |tee ip.txt |awk -F"/" '{print $1}' |awk '{print $2}'   	//将前面内容tee输入重定向到ip.txt文件里面去
127.0.0.1
172.16.60.1 

[root@fanhua ~]# 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@fanhua ~]# ip addr |grep 'inet ' |tee -a ip.txt |awk -F"/" '{print $1}' |awk '{print $2}'     -a追加
127.0.0.1 
172.16.60.1

[root@fanhua ~]# date >date.txt
[root@fanhua ~]# date |tee date.txt


[root@fanhua ~]# top -d 1 -bn 1 > top.txt
=
[root@fanhua ~]# top -d 1 -bn 1 |tee top.txt

top -d 1  一秒刷新一次top
top -d 1 -bn 1  一秒刷新一次top只执行一次
 类似资料: