在命令行中直接使用密码 ssh 登录
问题
需要在 shell 脚本中 ssh 登录远程服务器,上传下载文件,但由于 ssh 直接使用 TTY 访问,需要确保密码是用户键盘输入的,每次都需要输入密码,又没有添加免密登录,所以需要在脚本中直接使用密码执行操作。
解决方案
使用 sshpass 库,sshpass 在专门的 tty 中运行 ssh,以误导 ssh 相信它是从用户接收到的密码。
- 安装 sshpass 库:
- centos:
yum install sshpass unzip
- ubuntu:
apt-get install sshpass unzip
- centos:
- 用法:
- 执行命令:
sshpass -p $pwd ssh -p "$port" "$user@$ip" -o StrictHostKeyChecking=no "cmd"
- 复制文件:
sshpass -p $pwd scp -o StrictHostKeyChecking=no -P "$port" "$user@$ip:$remote_path" "$local_path"
- 执行命令: