今天公司的网站,有几个IP过于频繁的访问,频繁查询数据库,导致机器负载很高,于是根据实际情况 屏蔽掉访问频繁的IP,问题得以解决,在这里贴出来,供大家参考参考.
脚本需要根据实际的nginx log 格式,修改,取出 访问IP 和User-Agent.
在nginx配置文件中添加一条配置
include ./vhost/blockip.conf;
脚本内容:
#!/bin/bash nginx_home=/usr/local/webserver/nginx log_path=/usr/local/webserver/nginx/logs tail -n50000 /usr/local/webserver/nginx/logs/access.log \ |awk '{print $1,$12}' \ |grep -i -v -E "google|yahoo|baidu|msnbot|FeedSky|sogou" \ |awk '{print $1}'|sort|uniq -c|sort -rn \ |awk '{if($1>1000)print "deny "$2";"}' >$nginx_home/conf/vhost/blockip.conf /etc/init.d/nginx reload
这样之后,那几个IP被屏蔽,机器负载已经恢复正常;