ubuntu 16.04防止SSH暴力登录攻击

Posted 简一_hz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ubuntu 16.04防止SSH暴力登录攻击相关的知识,希望对你有一定的参考价值。

ubuntu 16.04防止SSH暴力登录攻击

 

最近观察服务器的认证日志,发现有些国外的IP地址,多次尝试破解服务器的密码进行登录。于是希望能将多次尝试SSH登录失败的IP阻止掉。

查看日志文件:

1

$ sudo cat /var/log/auth.log

看到很多如下的日志:

Failed password for root from 123.15.36.218 port 51252 ssh2
reverse mapping checking getaddrinfo for pc0.zz.ha.cn [218.28.79.228] failed – POSSIBLE BREAK-IN ATTEMPT!
Invalid user akkermans from 218.28.79.228
pam_unix(sshd:auth): check pass; user unknown
pam_unix(sshd:auth): authentication failure; logname= uid=0 euid=0 tty=ssh ruser= rhost=218.28.79.228

来统计一下有多少人在暴力破解root密码

 

1

2

3

4

5

6

$ sudo grep "Failed password for root" /var/log/auth.log | awk 'print $11' | sort | uniq -c | sort -nr | more

 

     16 212.237.47.236

      5 42.120.74.106

      4 ;

      1 80.211.140.131

如果已经禁用了root登录,则看一下暴力猜用户名的统计信息

 

1

2

3

4

5

$ sudo grep "Failed password for invalid user" /var/log/auth.log | awk 'print $13' | sort | uniq -c | sort -nr | more

 

    129 212.237.47.236

      3 ;

      1 80.211.140.131

某个人尝试了129次。为了防范于未然,我们可以做些配置,让服务器更加安全。

下面的三个方法,可以完全使用,也可以部分使用。一般建议使用其中的第一条跟第三条。

1. 修改SSH端口,禁止root登陆

修改/etc/ssh/sshd_config文件

 

1

2

3

4

5

6

$ sudo vim /etc/ssh/sshd_config

 

Port 4484 #一个别人猜不到的端口号

PermitRootLogin no

 

$ sudo service sshd restart

 

2. 禁用密码登陆,使用RSA私钥登录

如果服务器只允许使用私钥登录的,但是如果想在别的电脑上临时SSH上来,又没带私钥文件的情况下,就很麻烦。所以还是保留密码验证登录。不管怎样,这一条还是先列出来

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

# 在客户端生成密钥

$ ssh-keygen -t rsa

 

# 把公钥拷贝至服务器

$ ssh-copy-id -i .ssh/id_rsa.pub server

 

# 也可以手动将.shh/id_rsa.pub拷贝至服务器用户目录的.ssh中,记得修改访问权限

# $ scp .shh/id_rsa.pub server:~/.ssh

 

# 在服务器中

$ cd ./.ssh/

 

$ mv id_rsa.pub authorized_keys

 

$ chmod 400 authorized_keys

 

$ vim /etc/ssh/sshd_config

 

RSAAuthentication yes #RSA认证

PubkeyAuthentication yes #开启公钥验证

AuthorizedKeysFile .ssh/authorized_keys #验证文件路径

PasswordAuthentication no #禁止密码认证

PermitEmptyPasswords no #禁止空密码

UsePAM no #禁用PAM

 

 

# 最后保存,重启

$ sudo service sshd restart

 

3. 安装denyhosts

denyhostsPython语言写的一个程序,它会分析sshd的日志文件,当发现重复的失败登录时就会记录IP/etc/hosts.deny文件,从而达到自动屏IP的功能。现今denyhosts在各个发行版软件仓库里都有。

注意在ubuntu 16.04系统上,如果通过远程的SSH登录到服务器上执行安装命令的话,会由于默认情况下RESET_ON_SUCCESS = yes #如果一个ip登陆成功后,失败的登陆计数是否重置为0这部分,默认情况下是关闭的。而如果恰好我们又出现自己输入的错误密码错误累计次数超过5次的情况(即使后面有成功登录的记录也不行),会导致我们自己当前登录的地址也被阻止的情况。这种情况发生之后,会导致我们自己无法控制服务器(这个阻塞是在iptables层阻塞的,如果要恢复,在iptables中删除已经添加的记录才可以)。解决办法就是换一个新的IP地址登录服务器,然后修改RESET_ON_SUCCESS这个参数,并重启denyhosts服务。如果是阿里云或者腾讯云的服务器,可以尝试从他们网站上提供的网页版本的Shell进行操作。

对于ubuntu 16.04系统,建议使用如下方式进行安装:

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

#创建执行脚本

$ touch ~/install.sh

 

#创建执行安装命令,整个过程不中断连续执行,如果不使用脚本,执行到这里,可能SSH就已经被阻断了

#安装完成后,denyhosts的服务就已经开始运行了,此时可能已经设置了iptables了

$ echo "sudo apt-get install denyhosts" >> ~/install.sh

 

#创建修改配置文件的命令

$ echo "sudo sed -i 's/^#RESET_ON_SUCCESS/RESET_ON_SUCCESS/g' /etc/denyhosts.conf" >> ~/install.sh

 

#创建重启服务的命令

$ echo "sudo service denyhosts restart" >> ~/install.sh

 

#执行我们刚刚的安装脚本

$ sudo bash ~/install.sh

默认配置就能很好的工作,如要个性化设置可以修改/etc/denyhosts.conf

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

$ sudo vim /etc/denyhosts.conf

 

SECURE_LOG = /var/log/auth.log #ssh 日志文件,它是根据这个文件来判断的。

HOSTS_DENY = /etc/hosts.deny #控制用户登陆的文件

PURGE_DENY = #过多久后清除已经禁止的,空表示永远不解禁

BLOCK_SERVICE = sshd #禁止的服务名,如还要添加其他服务,只需添加逗号跟上相应的服务即可

DENY_THRESHOLD_INVALID = 5 #允许无效用户失败的次数

DENY_THRESHOLD_VALID = 10 #允许普通用户登陆失败的次数

DENY_THRESHOLD_ROOT = 1 #允许root登陆失败的次数

DENY_THRESHOLD_RESTRICTED = 1

WORK_DIR = /var/lib/denyhosts #运行目录

SUSPICIOUS_LOGIN_REPORT_ALLOWED_HOSTS=YES

HOSTNAME_LOOKUP=YES #是否进行域名反解析

LOCK_FILE = /var/run/denyhosts.pid #程序的进程ID

ADMIN_EMAIL = root@localhost #管理员邮件地址,它会给管理员发邮件

SMTP_HOST = localhost

SMTP_PORT = 25

SMTP_FROM = DenyHosts <nobody@localhost>

SMTP_SUBJECT = DenyHosts Report

AGE_RESET_VALID=5d #用户的登录失败计数会在多久以后重置为0,(h表示小时,d表示天,m表示月,w表示周,y表示年)

AGE_RESET_ROOT=25d

AGE_RESET_RESTRICTED=25d

AGE_RESET_INVALID=10d

RESET_ON_SUCCESS = yes #如果一个ip登陆成功后,失败的登陆计数是否重置为0

DAEMON_LOG = /var/log/denyhosts #自己的日志文件

DAEMON_SLEEP = 30s #当以后台方式运行时,每读一次日志文件的时间间隔。

DAEMON_PURGE = 1h #当以后台方式运行时,清除机制在 HOSTS_DENY 中终止旧条目的时间间隔,这个会影响PURGE_DENY的间隔。

查看/etc/hosts.deny发现里面已经有3条记录。

 

1

2

$ sudo cat /etc/hosts.deny | wc -l

3

目前ubuntu 16.04系统源里的denyhosts存在一个BUG,就是系统重启之后,iptables中的拦截设置没有恢复。具体的讨论以及描述,参考Iptables not persistent,代码应该已经增加了,目前还没合并到主分支。

以上是关于ubuntu 16.04防止SSH暴力登录攻击的主要内容,如果未能解决你的问题,请参考以下文章

腾讯云CVM&Linux CentOS 7 防止暴力SSH登录实践

腾讯云CVM&Linux CentOS 7 防止暴力SSH登录实践

Linux SSH密码暴力破解技术及攻击实战

Ubuntu16.04如何发现隐藏的ssh登录行为

Ubuntu16.04 ssh root登录

markdown Ubuntu 16.04 LTS安装ssh允许远程登录