使用Denyhosts防止黑客SSHD扫描

环境:Ubuntu Server 12.04

denyhost是一个由Python写的脚本,目前最新版本为2.6,可以实现对自动查找恶意ssh连接,然后把恶意ip加入到/etc/hosts.deny文件里面,以实现对服务器的安全防护

安装denyhost  # apt-get install mailutils            //安装邮件功能,以实现当有黑客攻击的时候报警到管理员邮箱  # apt-get install denyhosts        //安装denyhost软件,以实现防黑客扫描 

查看并配置denyhosts

root@node2:~# cat /etc/denyhosts.conf  | grep -v "^$"| grep -v "^#"

       ############ THESE SETTINGS ARE REQUIRED ############        //这些设定是必须的  SECURE_LOG = /var/log/auth.log                        //指定sshd的日志文件,里面已经内置了一些日志文件的位置,只需要打开即可,打开的方法为删除#号。  HOSTS_DENY = /etc/hosts.deny        //指定可以限制IP地址的文件,这里使用/etc/hosts.deny  PURGE_DENY = 5m                             //过多长时间,把IP从/etc/hosts.deny里面清除  BLOCK_SERVICE  = sshd                    //指定被保护的服务,这里要保护的是sshd  DENY_THRESHOLD_INVALID = 1        //允许无效用户失败的次数,在/etc/passwd里面没有的用户(不包括root)  DENY_THRESHOLD_VALID = 2            //允许正常用户失败的次数,在/etc/passwd里面有的用户(不包括root)  DENY_THRESHOLD_ROOT = 1            //允许root用户失败的次数  DENY_THRESHOLD_RESTRICTED = 1    //允许在$WORK_DIR/hosts-restricted里面出现的用户失败的次数  WORK_DIR = /var/lib/denyhosts            //定义工作目录  SUSPICIOUS_LOGIN_REPORT_ALLOWED_HOSTS=YES    //如果为YES,所有在$WORK_DIR/allowed-host时面的IP地址将会被认为是可疑的,如果设置为NO,所有在allowd-hosts试图登陆的结果,将不会发送警告邮件!所有不在$WORK_DIR/allowed-host时面的IP地址将会发送警告!  HOSTNAME_LOOKUP=YES        //是否将IP地址解析为主机名,告警的时候使用主机名。  LOCK_FILE = /run/denyhosts.pid        //定义PID文件的位置,确保同时只有一个Denyhost进程在运行         ############ THESE SETTINGS ARE OPTIONAL ############        //这里的设置是可选的  ADMIN_EMAIL = gm100861@gmail.com               //当有人试图登录你的服务器,或者有IP被加入黑名单的时候,发送邮件到这里指定的邮箱。前提是,本机一定要可以发送邮件才行!  SMTP_HOST = localhost                //指定smtp服务器  SMTP_PORT = 25                            //指定SMTP端口号  SMTP_FROM = DenyHosts <nobody@localhost>        //指定发件人  SMTP_SUBJECT = DenyHosts Report                        //指定邮件主题  AGE_RESET_VALID=5d                    //多长时间后,用户登录失败的次数被置为0,这里是指在/etc/passwd里面定义的用户,如果不设置,永远都不会置0  AGE_RESET_ROOT=25d            //多长时间后,root用户登录失败的次数置为0,如果不设置,永远都不会置0  AGE_RESET_RESTRICTED=25d    //在$WORK_DIR/hosts-restricted时面定义的用户,多长时间失败次数计数器被置为0  AGE_RESET_INVALID=10d            //无效用户(不在/etc/passwd里面的用户)的失败次数计数器,多长时间被置为0  RESET_ON_SUCCESS = yes            //当某个IP使用某个用户登录成功后,该IP对应的用户失败次数将会被置为0     ######### THESE SETTINGS ARE SPECIFIC TO DAEMON MODE  ##########  DAEMON_LOG = /var/log/denyhosts        //当denyhost运行在守护进程模式的时候,日志文件存储的位置     DAEMON_SLEEP = 30s                    //轮询查看SSHD日志的间隔  DAEMON_PURGE = 1h                //多长时间清空$HOSTS_DENY中的IP地址,如果PURGE_DENY为空,这个设置将无效     #########   THESE SETTINGS ARE SPECIFIC TO     ##########     #########       DAEMON SYNCHRONIZATION         ########## 

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwydxy.html