搜索
 找回密码
 立即注册

【保姆级】配置linux服务器使用证书登录,不用再每个服务器记不同的密码了,安全还省心

牛气冲天 2023-06-25 10:22 267
当我们的服务器多了之后记住密码就会特别麻烦,设置成一样的密码又不安全,有没有一种办法可以解决呢

答案是肯定的,我们可以为不同的服务器配置同一个证书登录,这样就可以一把钥匙走天下了,安全还省心

一、生成证书和私钥
在客户端电脑上使用ssh-keygen命令生成证书和私钥。在终端中输入以下命令:
  1. ssh-keygen -t rsa -b 2048
复制代码
其中-t rsa表示使用RSA算法生成证书,-b 2048表示生成2048位长度的证书。生成证书时,需要输入文件名和密码等信息,可以直接按回车键使用默认值。
执行完以上命令后,会在~/.ssh目录下生成id_rsa和id_rsa.pub两个文件,其中id_rsa为私钥文件,id_rsa.pub为证书文件。将证书文件复制到服务器上。

二、配置服务器
在服务器上需要进行如下操作:
创建.ssh目录
在用户的主目录下创建.ssh目录,并设置其权限为700。
(我解释下,什么是用户主目录,比如你想用root账户登录,那么用户主目录就是/root,执行 cd /root 进入的那个目录)
  1. mkdir ~/.ssh
  2. chmod 700 ~/.ssh
复制代码
添加证书
将客户端生成的证书文件id_rsa.pub的内容添加到服务器的authorized_keys文件中。
  1. cat id_rsa.pub >> ~/.ssh/authorized_keys
复制代码
修改文件权限
设置authorized_keys文件的权限为600。
  1. chmod 600 ~/.ssh/authorized_keys
复制代码
修改sshd配置
修改sshd_config文件,启用证书登录。
  1. sudo vi /etc/ssh/sshd_config
复制代码
找到以下两行配置:
  1. #RSAAuthentication yes
  2. #PubkeyAuthentication yes
复制代码
将注释去掉,并将yes改为no,即修改为:
  1. RSAAuthentication no
  2. PubkeyAuthentication yes
复制代码
然后找到以下行配置:
  1. #AuthorizedKeysFile     .ssh/authorized_keys
复制代码
将注释去掉,并确保该行配置与以下相同:
  1. AuthorizedKeysFile     .ssh/authorized_keys
复制代码
保存并退出文件。
重启sshd服务
执行以下命令重启sshd服务。
  1. sudo systemctl restart sshd
复制代码
三、使用证书登录
在客户端电脑上执行以下命令使用证书登录到服务器。
  1. ssh -i ~/.ssh/id_rsa username@server_ip
复制代码
其中,-i选项指定使用的证书文件,username为服务器上的用户名,server_ip为服务器的IP地址或域名。
如果证书和私钥的文件名不是默认的id_rsa和id_rsa.pub,需要使用-i选项指定证书和私钥文件的路径。
  1. ssh -i /path/to/private_key username@server_ip
复制代码
当然也可以用xshell或者putty配置证书去登录


随机推荐

3 回复

tengchong
2023-6-26 21:35:55
牛逼,很实用,学习了
18cm
2023-6-26 21:50:17
牛逼,很实用,学习了
9527VS
2023-6-26 22:07:43
顶一个
游客
高级模式
返回顶部