nginx封禁访问次数过高的ip

该脚本功能用于监测Nginx日志,当某个IP访问次数超过1000次时,将其添加到防火墙的黑名单中。通过定时任务每10分钟执行一次,检查access.log,然后使用firewalld更新黑名单规则,实现动态IP封禁。
摘要由CSDN通过智能技术生成

脚本功能

封禁当天访问次数超过1000的ip

定时任务

[root@localhost tool]$ sudo crontab -u root -l
*/10 * * * * /data/tool/nginx_black_ip.sh > /data/tool/logs/nginx_black_ip.log

防火墙设置

firewall-cmd --permanent --zone=public --new-ipset=blacklist --type=hash:net
firewall-cmd --permanent --zone=public --add-rich-rule="rule family=ipv4 source ipset=blacklist  drop"
firewall-cmd --reload

脚本如下

#!/bin/bash
LogDir='/usr/local/nginx/logs/'
WorkDir='/data/tool'

#统计日志中访问次数超过1000的ip
awk '{a[$1]+=1}END{for(ip in a){if(a[ip]>1000) print ip}}' ${LogDir}.access.log > ${WorkDir}/ip/black_ip.txt

#将不在nginx白名单的ip加入到防火墙黑名单中
for ip in `cat ${WorkDir}/ip/black_ip.txt`
do
 if [[ `grep -c $ip ${WorkDir}/ip/white_ip.txt` -eq 0 && `firewall-cmd --ipset=blacklist --get-entries | grep -c $ip` -eq 0 ]];then
   echo $ip
   firewall-cmd --permanent --zone=public --ipset=blacklist --add-entry=$ip
   firewall-cmd --reload
 fi
 

done

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值