查看原文
其他

ssh免密码登录远程服务器

2017-05-29 陈同 生信宝典

最简单的操作

ssh免密码登录的原理是把本地电脑的公钥放在宿主机,然后使用本地电脑的私钥去认证。

在本地电脑执行 /usr/bin/ssh-keygen -t rsa,安装提示一直回车即可,最后会看到~/.ssh目录下多了几个文件id_rsa (私钥) id_rsa.pub (公钥).

在本地电脑执行 scp ~/.ssh/id_rsa.pub user@remote_server:拷贝~/.ssh/id_rsa.pub到需要远程登录的服务器的家目录下。

使用密码登录远程服务器,执行mkdir -p ~/.ssh; cat ~/id_rsa.pub >>~/.ssh/authorized_keys; chmod 700 ~/.ssh; chmod 600 >>~/.ssh/authorized_keys.

退出,再尝试登录,应该就不需要输入密码了。

更详细解释和问题解决请看原文链接。

使用sshpass非交互的ssh密码验证

sshpass是非交互性ssh登录工具,把密码作为参数或存储在配置文件中提供,省去了多次输入密码的麻烦。

sshpass安装:

wget 'https://downloads.sourceforge.net/project/sshpass/sshpass/1.06/sshpass-1.06.tar.gz?r=https%3A%2F%2Fsourceforge.net%2Fprojects%2Fsshpass%2F&ts=1496021628&use_mirror=jaist' -O sshpass-1.06.tar.gz tar xvzf sshpass-1.06.tar.gz cd sshpass* ./configure --prefix=/install_path make make install # 加入环境变量

(后台回复 环境变量 获取环境变量的解释和应用)

# 登录远程服务器
sshpass -p 'password' ssh user@remote_host  

# execute command from remote server
sshpass -p 'password' ssh user@remote_host 'ls'

# Remote login multiple servers; -tt should be used when error
# 'Pseudo-terminal will not be allocated because stdin is not a terminal' appears.
sshpass -p 'password' ssh -tt user@remote_host \
   'source ~/.bashrc; sshpass -p "password" ssh -tt user@another_remote_host "Execute other command"'

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存