nginx 加ip黑名单

1./usr/local/nginx/conf 创建黑名单文件 blacklist.conf
2. 编辑nginx.conf 添加: include       /usr/local/nginx/conf/blacklist.conf;

在这里插入图片描述

3.创建 shell脚本自动加入黑名单:
  取最近2000条数据,如果相同ip请求超过200次 将ip 加入 blacklist.conf,并重启 nginx

#!/bin/bash
#取最近2000条数据
tail -n2000 /usr/local/nginx/logs/access.log |awk '{print $1,$12}' |grep -i -v -E "google|yahoo|baidu|msnbot|FeedSky|sogou|360|bing|soso|403|admin" |awk '{print $1}'|sort|uniq -c|sort -rn |awk '{if($1>200)print "deny "$2";"}' >> /usr/local/nginx/conf/blacklist.conf
/usr/local/nginx/sbin/nginx -s reload

4.linux 创建定时任务执行shell脚本
crontab -e : 编辑 定时任务,每2分钟执行一遍
*/2 * * * * sh /usr/local/nginx/blackshell.sh
crontab -l: 列出定时任务脚本
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值