服务器之家:专注于服务器技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服务器之家 - 服务器系统 - Linux - VPS 防止SSH 暴力登录尝试攻击的配置方法

VPS 防止SSH 暴力登录尝试攻击的配置方法

2019-12-03 16:14服务器之家 Linux

前些时谈了一下如何屏蔽对网站服务器的扫描,属于前台防御。后来 Felix 发了一篇 blog 提到将多次尝试 SSH 登录失败的 IP ban 掉,才想起来去看一下日志,没想到后院起火了

前些时谈了一下如何屏蔽对网站服务器的扫描,属于前台防御。后来 Felix 发了一篇 blog 提到将多次尝试 SSH 登录失败的 IP ban 掉,才想起来去看一下日志,没想到后院起火了。 

查看日志文件: 

 

复制代码

代码如下:


$ sudo cat /var/log/auth.log 



没想到满屏满屏的往下刷,全是:
 

复制代码

代码如下:


$ sudo grep "Failed password for root" /var/log/auth.log | awk '{print $11}' | sort | uniq -c | sort -nr | more 
470 222.122.52.150 
411 123.15.36.218 
139 177.8.168.48 
20 74.81.83.226 
18 77.108.112.131 
2 95.58.255.62 
1 218.28.79.228 
1 188.132.163.154 



很明显我禁用了 root 登录,人家也不是那么笨,开始暴力猜用户名: 
 

复制代码

代码如下:


$ sudo grep "Failed password for invalid user" /var/log/auth.log | awk '{print $13}' | sort | uniq -c | sort -nr | more 
3190 218.28.79.228 
646 222.122.52.150 
172 123.15.36.218 
65 177.8.168.48 
4 222.76.211.149 



某个人尝试了 3000 多次,好吧,lovelucy 这个小博客真有那么 valuable 么。。为了防范于未然,我们可以做些配置,让 VPS 服务器更加安全。

 

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

修改/etc/ssh/sshd_config文件

 

复制代码

代码如下:


$ sudo vi /etc/ssh/sshd_config 
Port 4484 #一个别人猜不到的端口号 
PermitRootLogin no 
$ sudo /etc/init.d/ssh restart 



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

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

复制代码

代码如下:


# 在客户端生成密钥 
$ 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 
$ vi /etc/ssh/sshd_config 
RSAAuthentication yes #RSA认证 
PubkeyAuthentication yes #开启公钥验证 
AuthorizedKeysFile .ssh/authorized_keys #验证文件路径 
PasswordAuthentication no #禁止密码认证 
PermitEmptyPasswords no #禁止空密码 
UsePAM no #禁用PAM 
# 最后保存,重启 
$ sudo /etc/init.d/ssh restart 



3、安装denyhosts

 

这个方法比较省时省力。denyhosts 是 Python 语言写的一个程序,它会分析 sshd 的日志文件,当发现重复的失败登录时就会记录 IP 到 /etc/hosts.deny 文件,从而达到自动屏 IP 的功能。这和我之前介绍的自动屏蔽扫描的脚本 是一个思路。如果靠人工手动添加的话还不把人累死。现今 denyhosts 在各个发行版软件仓库里都有,而且也不需要过多配置,傻瓜易用。

安装:

 

复制代码

代码如下:


# Debian/Ubuntu: 
$ sudo apt-get install denyhosts 
# RedHat/CentOS 
$ yum install denyhosts 
# Archlinux 
$ yaourt denyhosts 
# Gentoo 
$ emerge -av denyhosts 



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

 

 

复制代码

代码如下:


$ vi /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 文件发现里面已经有 8 条记录。

延伸 · 阅读

精彩推荐
  • LinuxLinux中环境变量配置的步骤详解

    Linux中环境变量配置的步骤详解

    Linux中环境变量包括系统级和用户级,系统级的环境变量是每个登录到系统的用户都要读取的系统变量,而用户级的环境变量则是该用户使用系统时加载的...

    Myths7882022-02-10
  • Linux详解Linux系统下PXE服务器的部署过程

    详解Linux系统下PXE服务器的部署过程

    这篇文章主要介绍了Linux系统下PXE服务器的部署过程,包括对PXE的API架构作了一个基本的简介,需要的朋友可以参考下...

    运维之道9812019-07-04
  • LinuxLinux常用的日志文件和常用命令

    Linux常用的日志文件和常用命令

    成功地管理任何系统的关键之一,是要知道系统中正在发生什么事。 Linux 中提供了异常日志,并且日志的细节是可配置的。Linux 日志都以明文形式存储,所...

    Linux教程网2632020-04-18
  • Linux确保Linux系统安全的前提条件 漏洞防护

    确保Linux系统安全的前提条件 漏洞防护

    Linux 作为开放式的操作系统受到很多程序员的喜爱,很多高级程序员都喜欢编写Linux操作系统的相关软件。这使得Linux操作系统有着丰富的软件支持,还有无...

    Linux之家2642020-04-11
  • Linuxlinux中rmdir命令使用详解(删除空目录)

    linux中rmdir命令使用详解(删除空目录)

    今天学习一下linux中命令: rmdir命令。rmdir是常用的命令,该命令的功能是删除空目录,一个目录被删除之前必须是空的 ...

    linux命令大全5372019-11-19
  • Linux手把手教您在 Linux 上使用 GPG 加解密文件

    手把手教您在 Linux 上使用 GPG 加解密文件

    在本教程中,我将告诉你如何用 GPG 加密和解密文件。这是一个简单的教程,你可以在你的 Linux 系统上尝试所有的练习。这将帮助你练习 GPG 命令,并在你...

    Linux中国6962021-12-15
  • LinuxLinux lnmp下无法使用mail发邮件的两种解决方法

    Linux lnmp下无法使用mail发邮件的两种解决方法

    在配置了lnmp环境后,出现了mail函数不能发送邮件的问题,其实有两种方法,一是使用sendmail组件,而是使用postfix。下面为大家一一介绍下 ...

    Linux之家4042019-09-17
  • LinuxLinux上设置用户通过SFTP访问目录的权限的方法

    Linux上设置用户通过SFTP访问目录的权限的方法

    这篇文章主要介绍了Linux上设置用户通过SFTP访问目录的权限的方法,SFTP可以理解为使用SSH协议进行FTP传输的协议,因而同时要对OpenSSH进行相关设置,需要的朋...

    OSChina10022019-06-19