作者:手机用户2502853457 | 来源:互联网 | 2023-08-08 17:39
Top
NSD SHELL DAY06
- 案例1:awk流程控制
- 案例2:awk扩展应用
- 案例3:编写监控脚本
- 案例4:编写安全检测脚本
1 案例1:awk流程控制
1.1 问题
本案例要求了解awk的流程控制操作,可自行设置awk语句来有验证以下操作:
- if分支结构(单分支、双分支、多分支)
- 练习awk数组的使用
1.2 步骤
实现此案例需要按照如下步骤进行。
步骤一:awk过滤中的if分支结构
1)单分支
统计/etc/passwd文件中UID小于或等于1000的用户个数:
[root&#64;svr5 ~]# awk -F: &#39;{if($3<&#61;1000){i&#43;&#43;}}END{print i}&#39; /etc/passwd
39
统计/etc/passwd文件中UID大于1000的用户个数&#xff1a;
[root&#64;svr5 ~]# awk -F: &#39;{if($3>1000){i&#43;&#43;}}END{print i}&#39; /etc/passwd
8
统计/etc/passwd文件中登录Shell是“/bin/bash”的用户个数&#xff1a;
[root&#64;svr5 ~]# awk -F: &#39;{if($7~/bash$/){i&#43;&#43;}}END{print i}&#39; /etc/passwd
29
2&#xff09;双分支
分别统计/etc/passwd文件中UID小于或等于1000、UID大于1000的用户个数&#xff1a;
[root&#64;svr5 ~]# awk -F: &#39;{if($3<&#61;1000){i&#43;&#43;}else{j&#43;&#43;}}END{print i,j}&#39; /etc/passwd
39 8
分别统计/etc/passwd文件中登录Shell是“/bin/bash”、 登录Shell不是“/bin/bash”的用户个数&#xff1a;
[root&#64;svr5 ~]# awk -F: &#39;{if($7~/bash$/){i&#43;&#43;}else{j&#43;&#43;}} END{print i,j}&#39; /etc/passwd
29 38
步骤二&#xff1a;awk数组
1&#xff09;数组的语法格式
数组是一个可以存储多个值的变量&#xff0c;具体使用的格式如下&#xff1a;
定义数组的格式&#xff1a;数组名[下标]&#61;元素值
调用数组的格式&#xff1a;数组名[下标]
遍历数组的用法&#xff1a;for(变量 in 数组名){print 数组名[变量]}。
[root&#64;svr5 ~]# awk &#39;BEGIN{a[0]&#61;11;a[1]&#61;88;print a[1],a[0]}&#39;
88 11
[root&#64;svr5 ~]# awk &#39;BEGIN{a&#43;&#43;;print a}&#39;
1
[root&#64;svr5 ~]# awk &#39;BEGIN{a0&#43;&#43;;print a0}&#39;
1
[root&#64;svr5 ~]# awk &#39;BEGIN{a[0]&#43;&#43;;print a[0]}&#39;
1
[root&#64;svr5 ~]# awk &#39;BEGIN{a[0]&#61;0;a[1]&#61;11;a[2]&#61;22; for(i in a){print i,a[i]}}&#39;
0 0
1 11
2 22
注意&#xff0c;awk数组的下标除了可以使用数字&#xff0c;也可以使用字符串&#xff0c;字符串需要使用双引号&#xff1a;
[root&#64;svr5 ~]# awk &#39;BEGIN{a["hehe"]&#61;11;print a["hehe"]}&#39;
11
2 案例2&#xff1a;awk扩展应用
2.1 问题
本案例要求使用awk工具完成下列两个任务&#xff1a;
- 分析Web日志的访问量排名&#xff0c;要求获得客户机的地址、访问次数&#xff0c;并且按照访问次数排名
2.2 方案
1&#xff09;awk统计Web访问排名
在分析Web日志文件时&#xff0c;每条访问记录的第一列就是客户机的IP地址&#xff0c;其中会有很多重复的IP地址。因此只用awk提取出这一列是不够的&#xff0c;还需要统计重复记录的数量并且进行排序。
通过awk提取信息时&#xff0c;利用IP地址作为数组下标&#xff0c;每遇到一个重复值就将此数组元素递增1&#xff0c;最终就获得了这个IP地址出现的次数。
针对文本排序输出可以采用sort命令&#xff0c;相关的常见选项为-r、-n、-k。其中-n表示按数字顺序升序排列&#xff0c;而-r表示反序&#xff0c;-k可以指定按第几个字段来排序。
2.3 步骤
实现此案例需要按照如下步骤进行。
步骤一&#xff1a;统计Web访问量排名
分步测试、验证效果如下所述。
1&#xff09;提取IP地址及访问量
[root&#64;svr5 ~]# awk &#39;{ip[$1]&#43;&#43;} \
> END{for(i in ip) {print ip[i],i }}&#39; /var/log/httpd/access_log
4 127.0.0.1
17 192.168.4.5
13 192.168.4.110
.. ..
2&#xff09;对第1&#xff09;步的结果根据访问量排名
[root&#64;svr5 ~]# awk &#39;{ip[$1]&#43;&#43;} END{for(i in ip) {print i,ip[i]}}&#39; /var/log/httpd/access_log | sort -nr
17 192.168.4.5
13 192.168.4.110
4 127.0.0.1
.. ..
3 案例3&#xff1a;编写监控脚本
3.1 问题
本案例要求编写脚本&#xff0c;实现计算机各个性能数据监控的功能&#xff0c;具体监控项目要求如下&#xff1a;
- CPU负载
- 网卡流量
- 内存剩余容量
- 磁盘剩余容量
- 计算机账户数量
- 当前登录账户数量
- 计算机当前开启的进程数量
- 本机已安装的软件包数量
3.2 步骤
实现此案例需要按照如下步骤进行。
步骤一&#xff1a;准备工作
1&#xff09;查看性能数据的命令
[root&#64;svr5 ~]# uptime //查看CPU负载
[root&#64;svr5 ~]# ifconfig eth0 //查看网卡流量
[root&#64;svr5 ~]# free //查看内存信息
[root&#64;svr5 ~]# df //查看磁盘空间
[root&#64;svr5 ~]# wc -l /etc/passwd //查看计算机账户数量
[root&#64;svr5 ~]# who |wc -l //查看登录账户数量
[root&#64;svr5 ~]# rpm -qa |wc -l //查看已安装软件包数量
步骤二&#xff1a;编写参考脚本
1&#xff09;脚本内容如下&#xff1a;
[root&#64;svr5 ~]# vim test.sh
#!/bin/bash
ip&#61;&#96;ifconfig eth0 | awk &#39;/inet /{print $2}&#39;&#96;
echo "本地IP地址是:"$ip
cpu&#61;&#96;uptime | awk &#39;{print $NF}&#39;&#96;
#awk中NF为当前行的列数&#xff0c;$NF是最后一列
echo "本机CPU最近15分钟的负载是:"$cpu
net_in&#61;&#96;ifconfig eth0 | awk &#39;/RX p/{print $5}&#39;&#96;
echo "入站网卡流量为:"$net_in
net_out&#61;&#96;ifconfig eth0 | awk &#39;/TX p/{print $5}&#39;&#96;
echo "出站网卡流量为:"$net_out
mem&#61;&#96;free | awk &#39;/Mem/{print $4}&#39;&#96;
echo "内存剩余容量为:"$mem
disk&#61;&#96;df | awk &#39;/\/$/{print $4}&#39;&#96;
echo "根分区剩余容量为:"$disk
user&#61;&#96;cat /etc/passwd |wc -l&#96;
echo "本地账户数量为:"$user
login&#61;&#96;who | wc -l&#96;
echo "当前登陆计算机的账户数量为:"$login
process&#61;&#96;ps aux | wc -l&#96;
echo "当前计算机启动的进程数量为:"$process
soft&#61;&#96;rpm -qa | wc -l&#96;
echo "当前计算机已安装的软件数量为:"$soft
4 案例4&#xff1a;编写安全检测脚本
4.1 问题
本案例要求编写脚本&#xff0c;防止远程ssh暴力破解密码&#xff0c;具体监控项目要求如下&#xff1a;
- 检测ssh登录日志&#xff0c;如果远程登陆账号名错误3次&#xff0c;则屏蔽远程主机的IP
- 检测ssh登录日志&#xff0c;如果远程登陆密码错误3次&#xff0c;则屏蔽远程主机的IP
4.2 步骤
实现此案例需要按照如下步骤进行。
步骤一&#xff1a;准备工作
1&#xff09;过滤帐户名失败的命令(登陆日志文件为/var/log/secure)
[root&#64;svr5 ~]# awk &#39;/Invalid user/{print $10}&#39; /var/log/secure
2&#xff09;过滤密码失败的命令
[root&#64;svr5 ~]# awk &#39;/Failed password/{print $11}&#39; /var/log/secure
步骤二&#xff1a;编写参考脚本
1&#xff09;脚本内容如下&#xff1a;
[root&#64;svr5 ~]# vim test.sh
#!/bin/bash
awk &#39;/Failed password/{print $11}&#39; /var/log/secure | awk &#39;{ip[$1]&#43;&#43;}END{for(i in ip){print ip[i],i}}&#39; | awk &#39;$1>3{print $2}&#39;
awk ‘/Invalid user/{print $10}’ /var/log/secure | awk ‘{ip[$1]&#43;&#43;}END{for(i in ip){print ip[i],i}}’ | awk ‘$1>3{print $2}’