• 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只执行一次