近期,快要邻近春节,安全方面更加重要。
首先要对操作系统的用户做安全监控,防止操作系统账号被爆破泄露,我们也要监控起来。
(1)Zabbix记录每分钟日志登录失败的次数
(2)Zabbix记录登录失败用户的信息,方便查看
首先,我们整个集群日志,通过rsyslog服务,把上千台的日志同步到一台上,所以我们只需要监控这个rsyslog的服务端就可以了。
看效果图(这样一来,十分方便查看记录)
data:image/s3,"s3://crabby-images/7db28/7db2883bc750f6f9e9d14170f629768d88e507c5" alt=""
data:image/s3,"s3://crabby-images/2f08a/2f08ae8914c030aa76b998f88c6e643818a8676e" alt=""
data:image/s3,"s3://crabby-images/ce044/ce044732d34dbf2e92f7be9cf458c84511bc500f" alt=""
data:image/s3,"s3://crabby-images/6b4c0/6b4c0958caa1188664a13139e37bb80e6e303643" alt=""
(1) 登录失败次数
日志格式
1
|
2021-12-29T15:04:16.264895+08:00 127.0.0.1 [sshd] notice: pam_unix(sshd:auth): authentication failure; logname= uid=0 euid=0 tty=ssh ruser= rhost=172.17.9.200 user=deployer
|
编写代码的脚本
1
2
3
4
5
6
7
8
9
10
11
|
#!/bin/bash
LOG_PATH="/var/log/secure"
mon=$(date +%B)
h=$(date +%d)
ms=$(date +%H:%M)
#表示字符开头为0就替换为空
h=${h/#0/""}
k="T" #我这边有T,有的是空格,根据时间环境使用
count=`grep "$h$k$ms" /var/log/secure | grep -v sudo | grep -c "authentication failure" `
echo $count
|
修改zabbix客户端配置
1
2
|
#====================检查 账号登录失败次数======================
UserParameter=check_failed,sh /usr/local/zabbix-v503/scripts/check_failed.sh
|
重启zabbix客户端
zabbix界面配置
检查配置
data:image/s3,"s3://crabby-images/d99ad/d99adf8fc5aacdc87b670d64888df4f562f48756" alt=""
触发器
data:image/s3,"s3://crabby-images/b0e69/b0e69f41a468107da0bbd7e28dbf9197cf22f16d" alt=""
(2)失败日志记录
编写脚本
1
2
3
4
5
6
7
8
9
10
11
12
|
[root@logserver01 zabbix-v503]# cat scripts/check_failedlog.sh
#!/bin/bash
LOG_PATH="/var/log/secure"
mon=$(date +%B)
h=$(date +%d)
#获取前一分钟的爆破日志记录的时间 时:分
ms=$(date -d "1 minute ago" +"%H:%M")
#表示字符开头为0就替换为空
h=${h/#0/""}
k="T"
grep "$h$k$ms" /var/log/secure | grep -v sudo | grep "authentication failure" >> /usr/local/zabbix-v503/scripts/fail.log
|
开启定时任务(每分钟检查一次)
1
2
|
#-------check_fail_user_log-----------------
* * * * * sh /usr/local/zabbix-v503/scripts/check_failedlog.sh
|
如果有登录失败的,会单独过滤出来
data:image/s3,"s3://crabby-images/709aa/709aa92fa51d909435948458d130d0d768a1f305" alt=""
zabbix界面配置
1
|
log[/usr/local/zabbix-v503/scripts/fail.log,"sshd",skip,]
|
data:image/s3,"s3://crabby-images/1eff6/1eff63dc36112a41654780fc76eb979af1c72692" alt=""
已经完成相关的项目类容,很容易监控。
data:image/s3,"s3://crabby-images/a60ac/a60ac635cdde21e617e8086925cd986a6c182509" alt=""
根据触发器,可以设置值,如果每分钟爆破登录失败10次,就报警,有爆破的嫌疑