Nginx拦截、自动封禁 攻击方IP

7 篇文章 0 订阅
该脚本读取Nginx的access.log,统计访问IP并筛选出访问次数超过2次的IP,将这些IP写入blockip.conf以阻止访问。如果无重复IP,则更新Nginx配置并重新加载。此外,设置了每分钟执行一次的crontab任务来自动化此过程。
摘要由CSDN通过智能技术生成
#!/bin/bash
NGINX_HOME="/usr/local/nginx"
ACCESS_LOG="$NGINX_HOME/logs/access.log"

cat $ACCESS_LOG >> $NGINX_HOME/logs/access.log-all
echo "" > $NGINX_HOME/conf/blockip.conf

ip_list=$(awk '{print$1}' $ACCESS_LOG | sort -n | uniq -c | awk '$1>2 {print $2}')
if test -z "$ip_list"
then
$NGINX_HOME/sbin/nginx -s reload
else
  for ip in $(echo $ip_list)
do
  echo "deny" $ip";" >> $NGINX_HOME/conf/blockip.conf
done
$NGINX_HOME/sbin/nginx -s reload
fi
echo "" > $ACCESS_LOG

设置定时任务:crontab -e */1 * * * *  文件名.sh   每分钟执行一次

添加最后一行:include blockip.conf;写入执行文件conf里 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

R1chArd_TvT

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值