1.使用ssh-keygen -t rsa命令,生成一个rsa密钥对,一路回车即可。
默认生成的密钥文件在root/.ssh目录下。
ssh-keygen -t rsa
data:image/s3,"s3://crabby-images/4528a/4528a65e36df908445fa86ec98e8487f2ad32c57" alt=""
2.检查下.ssh目录下authorized_keys文件是否存在,没有的话,创建一个,然后将id_rsa.pub的内容追加到authorized_keys文件尾。
cd .ssh
cat id_rsa.pub >> authorized_keys
data:image/s3,"s3://crabby-images/66c0d/66c0db72e958ba8ae96f379e21553fc3e4b6dacf" alt=""
3.修改.ssh的权限为700
, authorized_keys的权限为600或者更严格的400
,否则登录的时候会提示server refuse you key。
chmod 700 /root/.ssh
chmod 600 /root/.ssh/authorized_keys
data:image/s3,"s3://crabby-images/693c1/693c1d03c60e2b700956d976521dab56b2e1fea3" alt=""
4.修改ssh的配置
vim /etc/ssh/sshd_config
#CentOS7.4相对于之前版本,做了一些与sshd相关的安全更新来加强sshd的安全性。其中之一就是弃用RSAAuthentication支持,anolis8.8也不需要添加RSAAuthentication
data:image/s3,"s3://crabby-images/39f26/39f2690bd5787ea508b4a26555dc12e7d95c6cbe" alt=""
5.将/root/.ssh/id_rsa文件保存在本地(可将文件名修改成任意名.pem结尾的文件)
6.重启sshd服务验证密钥是否能登录
systemctl restart sshd
7.禁用密码登录
vim /etc/ssh/sshd_config
data:image/s3,"s3://crabby-images/45145/45145e28daa3e129976b180bd464c5aa0d2ee9e3" alt=""
将PasswordAuthentication 设置为no,保存退出后重启服务器
8.linux上ssh连接服务器
把私钥214root.pem文件
复制到客户机上,使用ssh root@192.168.8.124 -i 214root.pem命令进行登录
data:image/s3,"s3://crabby-images/8b215/8b215bcfb0386b5ec6f6018b6a78ae1202d7fab6" alt=""
这个错误表明私钥文件的权限设置过于宽松,安全性不足,因此SSH拒绝使用它进行连接。修改密钥文件权限为400即可