今天给大家分享一些云计算学习路线课程大纲资料,这篇文章是关于进程管道 Piping的一些学习笔记资料,希望能给大家一些帮助: ==================================================================================== · 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@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 ~]# //以: 分隔,将第三列按字数升序 [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个进程0 [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 ~]# yum -y install httpd [root@tianyun ~]# systemctl start httpd [root@tianyun ~]# systemctl stop firewalld [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 ' |tee ip.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 >date.txt [root@tianyun ~]# date |tee date.txt [root@tianyun ~]# top -d 1 -b -n 1 > top.txt [root@tianyun ~]# top -d 1 -b -n 1 |tee top.txt |
|