本文作者:qiaoqingyi

s编程教材(小学编程教材)

qiaoqingyi 2023-10-05 115

  纯手工打造每一篇开源资讯与技术干货,数十万程序员和Linuxer已经关注。

导读

闲来无事,登陆服务器,发现有个IP不断的猜测路径、试图往服务器上传文件(木马)。

于是查看了之前的日志,无奈鄙站被攻击者盯上了,不断的有不同的IP试图上传木马。看来坏人还是有的。由于不想让鄙站沦为肉鸡,所以就想写个简单的脚本,来阻止攻击者的IP访问。

攻击者:

  195.154.216.165 - - [28/Nov/2015:23:10:40 +0800] "POST /wp-content/themes/twentyten/404.php HTTP/1.1" 404 27 " HTTP/1.1" 404 564 "http://www.z-dig.com/11m.php" "Mozilla/4.0 (compatible; MSIE 9.0; Windows NT 6.1)" "-"195.154.216.165 - - [28/Nov/2015:23:10:41 +0800] "POST /yanyu/?q={${eval%28$_POST[u]%29}} HTTP/1.1" 404 1569 "http://www.z-dig.com/11m.php" "Mozilla/4.0 (compatible; MSIE 9.0; Windows NT 6.1)" "-"195.154.216.165 - - [28/Nov/2015:23:10:42 +0800] "POST /ztxxw/Images/images.asp HTTP/1.1" 404 1569 "http://www.z-dig.com/11m.php" "Mozilla/4.0 (compatible; MSIE 9.0; Windows NT 6.1)" "-"

  [root@z-dig www]# grep '195.154.216.165' 2015-11-28.access.log|wc -l[root@z-dig www]#

  [root@z-dig www]# curl ipinfo.io/195.154.216.165;echo''{ "ip": "195.154.216.165", "hostname": "fr.07.gs", "city": "", "region": "", "country": "FR", "loc": "48.8600,2.3500", "org": "AS12876 ONLINE S.A.S."}[root@z-dig www]#

法国的哥们竟然试了180多次!辛苦了。

用 shell 和定时任务来实现吧。_

网站跑在 Nginx 上,所以可以使用 Nginx 的 Deny 来拒绝攻击者的IP访问。

那么思路就出来了,定期(五分钟或十分钟)获取攻击者的IP,将IP放入到黑名单(Nginx 配置文件),并 reload 使其生效。

由于前期规划的比较好,网站的访问日志放在了一个指定的目录,Nginx 的错误日志也放在了一个指定的目录。网站的访问日志每日进行切割。Nginx 的错误日志没有进行切割。

下面就是我的思路和操作步骤:

通过 Nginx 的错误日志(为什么不使用访问日志)来获取攻击者的IP。之前没有对 Nginx 的错误日志进行定时切割,为了方便统计攻击者的IP所以,编写脚本并加入定时任务,使错误日志每小时切割一次,并且每小时对黑名单文件进行清空。

错误日志切割、清空黑名单脚本:

  [root@z-dig s]# cat rotate-nginx-error-logs.sh #!/bin/bash# Rotate nginx error logs and clean block ip 's configure file# Nginx pid file : /application/nginx/logs/nginx.pid# Nginx error logs directory : /data/logs/nginx# Block Ip 's configure file : /application/nginx/conf/website/blockip.conf # Default log name : error.log# Author : Mr.Zhou# E-mail : zhou@z-dig.comNGX_PID=/application/nginx/logs/nginx.pidNGINX_CMD=/application/nginx/sbin/nginxLOGS_DIR=/data/logs/nginxLOG_NAME=error.logBLOCK_IP_FILE=/application/nginx/conf/website/blockip.confcd $LOGS_DIR /usr/bin/rename $LOG_NAME $(/bin/date +%F-%H -d "last hour").$LOG_NAME $LOG_NAME /bin/kill -USR1 $(cat $NGX_PID)$BLOCK_IP_FILE $($NGINX_CMD -s reload)[root@z-dig s]#

获取攻击者IP脚本:

该脚本从 Nginx 的错误日志中统计出超过20次试图猜测路径或上传文件的IP,并将这些IP加入到 Nginx 的配置文件。若有新增加的IP则 reload Nginx 使配置文件生效,若没有新增IP则不进行reload。

  [root@z-dig s]# cat block-ip.sh #!/bin/bash# Author : Mr.Zhou# Email : zhou@z-dig.com# Website : http://www.z-dig.com# block ipERR_LOG=/data/logs/nginx/error.logBLOCK_IP_FILE=/application/nginx/conf/website/blockip.confBLOCKED_IP=/dev/shm/blocked-ip.txtBLOCK_IP=/dev/shm/block-ip.txtNGINX_CMD=/application/nginx/sbin/nginx/bin/cp $BLOCK_IP_FILE $BLOCKED_IP /bin/sed -nr 's#.*[^0-9](([0-9]+.){3}[0-9]+).*#1#p' $ERR_LOG |/bin/awk '{IP[$1]++}END{for (i in IP) print IP[i],i}'|/bin/awk '{if($120)print "deny "$2";"}' $BLOCK_IP /bin/grep -v -f $BLOCK_IP_FILE $BLOCK_IP $BLOCK_IP_FILE $($NGINX_CMD -s reload)[root@z-dig s]#

将拒绝指定IP访问的配置文件(黑名单)单独存放,并在 nginx 主配置文件中 include 进去。

  [root@z-dig conf]# grep blockip.conf nginx.conf include website/blockip.conf;[root@z-dig conf]#

blockip.conf 文件格式如下:

  [root@z-dig website]# cat blockip.conf deny 195.154.211.220;deny 195.154.188.28;deny 195.154.188.186;deny 180.97.106.161;deny 180.97.106.162;deny 180.97.106.36;deny 195.154.180.69;deny 195.154.211.26;deny 221.229.166.247;deny 180.97.106.37;deny 195.154.216.164;deny 195.154.216.165;[root@z-dig website]#

将脚本放入定时任务执行:

每小时对 Nginx 的错误日志进行切割并且清空一次被拒绝访问IP的配置文件,若不清空的话,此IP将终生不能访问,若它再次攻击则会再次进入黑名单,_。 清空命令放在了切割脚本的尾部。

可以自己决定统计频率,根据指定的频率执行脚本,获取攻击者的IP,若此IP已经在黑名单中,则会忽略掉(由于错误日志一小时切割一次,所以在一小时内会出现重复的IP)。然后把剩下的新攻击者的IP追加到黑名单。并 reload Nginx 。若没有新增的攻击者IP则什么都不做。

  [root@z-dig ~]# crontab -l# rotate nginx log everyday00 00 * * * /bin/bash /application/s/rotate-nginx-logs.sh /dev/null# rotate nginx error log every hour and clean the block ip file00 */1 * * * /bin/bash /application/s/rotate-nginx-error-logs.sh /dev/null# check hacker's ip every ten minutes*/10 * * * * /bin/bash /application/s/block-ip.sh /dev/null[root@z-dig ~]#

以下是脚本运行一段时间的攻击者IP

  [root@z-dig ~]# cat /application/nginx/conf/website/blockip.conf deny 195.154.211.220;deny 195.154.188.28;deny 195.154.188.186;deny 180.97.106.161;deny 180.97.106.162;deny 180.97.106.36;deny 195.154.180.69;deny 195.154.211.26;deny 221.229.166.247;deny 180.97.106.37;deny 195.154.216.164;deny 195.154.216.165;[root@z-dig ~]#

过段时间,再列出一份黑名单IP,看是否有变化。

  [root@z-dig ~]# cat /application/nginx/conf/website/blockip.conf deny 195.154.188.224;[root@z-dig ~]# curl ipinfo.io/195.154.188.224;echo ''{ "ip": "195.154.188.224", "hostname": "195-154-188-224.rev.poneytelecom.eu", "city": "", "region": "", "country": "FR", "loc": "48.8600,2.3500", "org": "AS12876 ONLINE S.A.S."}[root@z-dig ~]# grep '195.154.188.224' /data/logs/nginx/error.log |wc -l[root@z-dig ~]# grep '195.154.188.224' /data/logs/nginx/error.log |grep -v 'access forbidden' |wc -l[root@z-dig ~]# [root@z-dig ~]# tail -n 1 /data/logs/nginx/error.log 2015/11/30 10:47:53 [error] 30754#0: *37828 access forbidden by rule, client: 195.154.188.224, server: www.z-dig.com, request: "GET / HTTP/1.1", host: "www.z-dig.com", referrer: "http://www.z-dig.com"[root@z-dig ~]#

看来多少还是管点用的。一共 access forbidden by rule 了 102-24=78 次。

适当的改改脚本,保存黑名单的历史数据,定期将大于1000的IP直接放入iptables!

  原文来自: http://www.ttlsa.com/nginx/nginx-deny-ip-access/

s编程教材(小学编程教材)

  本文地址: http://www.linuxprobe.com/nginx-deny-ip-access.html编辑:杨鹏飞,审核员:岳国帅

让您学习到的每一节课都有所收获

  《Linux就该这么学》是由资深运维专家刘遄及全国多名红帽架构师(RHCA)基于最新RHEL7系统共同编写的高质量Linux技术自学教程,极其适合用于Linux技术入门教程或讲课辅助教材。

  ? 刘遄老师QQ:5604241 微信:gnu_chuan

  ? 学员助教QQ:5604674

  ?Linux技术交流A群(满):560843

  ? Linux技术交流B群:340829

  ? Linux技术交流C群:463590

  ? Linux技术交流D群:915246(新群,火热加群中……)

  ? 官方站点:www.linuxprobe.com

  ? 电脑在线阅读效果更佳:

  http://www.linuxprobe.com/chapter-00.html

按住图片3秒,即可自动关注。

点击左下角查看更多热门技术

阅读
分享