DenyHosts

DenyHosts是Python语言写的一个程序,它会分析SSHD的日志文件,当发现重复的攻击时就会记录IP到/etc/hosts.deny文件,从而达到自动屏蔽IP的功能。

项目地址:http://denyhosts.sourceforge.net/

下面是安装过程
****************************************************************
tar zxvf DenyHosts-2.6.tar.gz                             #解压源码包
cd DenyHosts-2.6                                          #进入安装解压目录
python setup.py install                                   #安装DenyHosts
cd /usr/share/denyhosts/                                  #默认安装路径
cp denyhosts.cfg-dist denyhosts.cfg                       #denyhosts.cfg为配置文件
cp daemon-control-dist daemon-control                     #daemon-control为启动程序
chown root daemon-control                                 #添加root权限
chmod 700 daemon-control                                  #修改为可执行文件
ln -s /usr/share/denyhosts/daemon-control /etc/init.d/denyhosts     #对daemon-control进行软连接,并改名为denyhosts方便管理

安装到这一步就完成了。
/etc/init.d/denyhosts start        #启动denyhosts
chkconfig denyhosts on             #将denghosts设成开机启动
******************************************************************

vi /usr/share/denyhosts/denyhosts.cfg       #编辑配置文件,另外关于配置文件一些参数,通过grep -v "^#" denyhosts.cfg查看
SECURE_LOG = /var/log/secure                #ssh 日志文件,redhat系列根据/var/log/secure文件来判断;Mandrake、FreeBSD根据 /var/log/auth.log来判断
                                            #SUSE则是用/var/log/messages来判断,这些在配置文件里面都有很详细的解释。
HOSTS_DENY = /etc/hosts.deny                #控制用户登陆的文件
PURGE_DENY = 30m                            #过多久后清除已经禁止的,设置为30分钟;
# ‘m’ = minutes
# ‘h’ = hours
# ‘d’ = days
# ‘w’ = weeks
# ‘y’ = years
BLOCK_SERVICE = sshd                 #禁止的服务名,当然DenyHost不仅仅用于SSH服务
DENY_THRESHOLD_INVALID = 1           #允许无效用户失败的次数
DENY_THRESHOLD_VALID = 3             #允许普通用户登陆失败的次数
DENY_THRESHOLD_ROOT = 3              #允许root登陆失败的次数
DAEMON_LOG = /var/log/denyhosts      #DenyHosts日志文件存放的路径,默认

更改DenyHosts的默认配置之后,重启DenyHosts服务即可生效:
/etc/init.d/denyhosts restart (services denyhosts restart)  #重启denyhosts

经过以上配置,对于加强服务器安全是起了相当大的作用。尤其是对于那些无聊的暴力破解更为有效果。

你可能感兴趣的:(python,ssh,配置管理,FreeBSD,SuSE)