有时我们想要通过其他的账户进行登录SSH,通常我们在登录的时候需要重新输入密码 。不过对于一些不想记太多密码的用户来说,这样就显得有些麻烦了,那么该怎么才能不输入密码进行登录呢?
解决方法:
1. 你需要以用户“aliceA”的身份登录到hostA上 。
2. 使用ssh-keygen生成一对rsa公私钥,生成的密钥对会存放在~/.ssh目录下 。
$ ssh-keygen -t rsa
3. 使用下面的命令在目标主机hostB上的aliceB用户目录下创建~/.ssh目录 。如果在aliceB@hostB上已经存在.ssh目录,这一步会被略过 。
【Linux取消SSH登录密码的方法】 $ ssh aliceB@hostB mkdir -p .ssh
4. 将hostA上用户“aliceA”的公钥拷贝到aliceB@hostB上,来实现无密码ssh 。
$ cat .ssh/id_rsa.pub | ssh aliceB@hostB ‘cat 》》 .ssh/authorized_keys’
自此以后,从aliceA@hostA上ssh到aliceB@hostB上再也不需要输入密码 。(小编译注:上述的创建目录并复制的操作也可以通过一个 ssh-copy-id 命令一步完成:ssh-copy-id -i ~/.ssh/id_rsa.pub aliceB@hostB)
疑难解答
1. 即使在密钥认证生效后,你可能仍然需要输入SSH密码 。如果遇到这种情况,请检查系统日志(如/var/log/secure)以查看是否出现下面的异常 。
Authentication refused: bad ownership or modes for file /home/aliceB/.ssh/authorized_keys
在这种情况下,密钥认证的失败是由于~/.ssh/authorized_keys文件的权限或拥有者不正确 。一般情况,如果这个文件对除了你之外的所有用户都可读,就会出现这个错误 。用下面的方式改变文件的权限以修正错误 。
$ chmod 700 ~/.ssh/authorized_keys
以上就是设置Linux系统中不输入密码登录SSH服务器的方法了 。有遇到这种情况的用户,就按照上面的方法进行设置吧 。
推荐阅读
- Linux系统SSH出现encountered 1 errors错误怎么办?
- 怎样取消超话关注
- 怎么取消微信王者荣耀授权
- excel怎么隐藏和取消隐藏行
- Linux系统安装Autossh的方法
- Linux安装g77编译器的技巧
- 在Linux命令环境下如何进行基于HTTP协议安全认证的GIT设置
- Linux如何使用命令更新文件目录时间
- 怎样取消无痕浏览模式
- Linux系统设置ssh连接中断时间的技巧