提高SSH的安全性

VPS首发Linux操作系统是Debian 5 Lenny,配置的确非常顺手,系统恢复上线的速度也非常快

但是我发现Debian太保守了,软件包的版本过于陈旧,于是还是决定选取一个上进一点的发行版

综合考虑自身情况,决定选取Gentoo,VPS分配了四个CPU,编译速度还是非常快的,没什么后顾之忧

但昨晚在配置VPS时,用netstat发现一个奇怪的IP在连22端口,马上tail -f看看,发现是每隔两秒的SSH暴力密码破解,可能看到对方是从用户名字典里一个个地匹配。不过还好,我的密码是九位数字加字母组合,要算出来还是要比较长的时间

我看了看那个IP,那也是一个Linux系统,开着Apache服务器的

至此为止吧,最重要是如果解决问题:

1、我先修改/etc/ssh/sshd_config,把SSH默认端口改了

2、我决定使用SSH的公钥认证,关掉密码认证,这里有好几步要做

第一步,修改/etc/ssh/sshd_config

# 禁止root登录
PermitRootLogin no
# 开启公钥认证
RSAAuthentication yes
PubkeyAuthentication yes
AuthorizedKeysFile .ssh/authorized_keys
# 关闭密码认证
PasswordAuthentication no

第二步,生成认证公钥和私钥
ssh-keygen -t rsa

这一步你可以再指定一个密码,进一步提高安全性

执行完成后,会生在~/.ssh/目录下生成id_rsa和id_rsa.pub

执行
cat ~/.ssh/id_rsa.pub > ~/.ssh/authorized_keys

指定sshd认证公钥

第三步,刚才生成的id_rsa就是你的认证私钥要,要好好保存。

我用的是xshell,把id_rsa导入,OK,之后就可以用证书认证来登陆

之前把密码认证的登陆方式关了,也是保证安全性的做法,如果你不设证书密码短语,那么拥有这个证书的客户端都可以登陆。

0%