用SHELL脚本来防止SSH和vsftpd暴力破解

原创
系统 Linux
作者有一台公网服务器,采用的是双备份策略,所以开发了vsftpd的21端口,近来作者发现有许多人在尝试暴力破解vsftpd和ssh,因此,作者根据/var/log/secure日志显示情况,自己动手写了个SHELL脚本来防止SSH和vsftpd暴力破解。

 【51CTO特稿】我的一台公网服务器,由于网站采取的是双备份策略,所以开放了vsftpd的21端口,近来发现许多人在尝试暴力破解vsftpd和ssh,我随便看了看/var/log/secure日志,显示如下:

118.33.110.52=2834
119.145.254.77=37
121.254.179.199=226
121.88.250.243=35
200.29.110.104=168
202.78.173.199=250
222.221.2.210=373

这里面除了119.145.254.77和121.88.250.243是正常的外,其它的基本都是恶意IP。

由于我的服务器是置于LVS集群后面,所以我原来想用iptables的recent模块解决这个问题的方法估计是行不通的。而且,服务器的系统安装的是CentOS 5.5 x86_64,iptables还暂时不支持此模块,报错如下:

iptables: Unknown error 18446744073709551615
iptables: Unknown error 18446744073709551615

而由于机器已经在跑重要的业务,我又不想去升级内核,免得影响正常的网站运营,所以iptables的想法暂时告一段落;后来我又想到用HostsDeny的方法来解决这个问题,感觉这个方法还是比较繁琐,还不如自己手动写脚本来解决这个麻烦,脚本内容如下:

#! /bin/bash
cat /var/log/secure|awk '/Failed/{print $(NF-3)}'|sort|uniq -c|awk '{print $2"="$1;}' > /root/black.txt
DEFINE="100"
for i in `cat /root/black.txt`
do
IP=`echo $i |awk -F= '{print $1}'`
NUM=`echo $i|awk -F= '{print $2}'`
if [ $NUM -gt $DEFINE ];
then
grep $IP /etc/hosts.deny > /dev/null
if [ $? -gt 0 ];
then
echo "sshd:$IP" >> /etc/hosts.deny
echo "vsftpd:$IP" >> /etc/hosts.deny
fi
fi
done

脚本思路如下:

由于/var/log/secure是以星期为轮询的,所以我们每次可以查看这个文件,利用SHELL脚本统计出其中访问失败比较频繁的IP,并定义一个阀值为100,如果大于100的话就将其放进/etc/hosts.deny文件,阻止其继续访问vsftpd和ssh;然后将其写进crontab计划列表里,每隔一段时间进行一次排查,如果下次排查的某IP次数又大于100,首先检查它在不在我们的黑名单,如果在的话就无视过去;如果不在,就继续添加进/etc/hosts.deny文件。

我的/etc/crontab文件***一行为

* */1 * * * root sh /root/hosts_deny.sh

即每隔1小时就重复执行一次这个脚本,这里也有一个情况要说明下,/var/log/secure是每隔一个星期轮询一次的,所以我们这里可以根据服务器的具体情况来配置多少时间执行一次此脚本,暴力破解频繁的机器可适当缩小这个周期。

我的公网机器运行脚本一段时间后,/etc/hosts.deny文件如下:

sshd:119.145.254.77
vsftpd:119.145.254.77
sshd:222.221.2.210
vsftpd:222.221.2.210
sshd:118.218.136.25
vsftpd:118.218.136.25
sshd:118.33.110.52
vsftpd:118.33.110.52
sshd:123.196.113.11
vsftpd:123.196.113.11
sshd:14.140.172.74
vsftpd:14.140.172.74
sshd:200.29.110.104
vsftpd:200.29.110.104
sshd:202.102.89.81
vsftpd:202.102.89.81
sshd:202.78.173.199
vsftpd:202.78.173.199

【编辑推荐】

  1. Linux/Unix下Shell快捷键操作大集合
  2. 大话Emacs Shell Mode:当Shell遇见Emacs
  3. Linux服务器安全初始化Shell脚本

 

责任编辑:黄丹 来源: 51CTO.com
相关推荐

2012-11-29 14:44:07

2022-08-06 13:04:27

LinuxSHH

2011-04-02 09:34:38

2022-08-10 08:43:46

僵尸网络DDoS功能SSH服务器

2019-02-25 18:03:15

2009-05-20 11:30:21

2023-09-11 07:17:30

2013-05-14 10:12:13

2013-08-19 15:14:02

2013-06-08 10:41:51

2013-04-18 09:52:56

2011-11-29 10:03:24

2012-01-01 22:08:10

2017-03-01 11:52:30

2015-10-19 11:44:00

2018-04-09 10:24:31

2010-08-18 10:17:12

2014-09-24 09:27:02

2009-08-10 15:47:20

2015-03-17 09:50:00

点赞
收藏

51CTO技术栈公众号