博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SSH 远程执行命令二三事
阅读量:6551 次
发布时间:2019-06-24

本文共 3094 字,大约阅读时间需要 10 分钟。

hot3.png

有时侯,利用 ssh 在本地执行远程机器的命令可以便捷地处理某些重复工作。我们希望做到:

免手工输入密码 支持执行多个命令,执行 shell 脚本 支持执行 sudo 的命令

免手工输入密码

我们可以使用 ssh 互信,sshpass 和 expect 等工具来避免手工输密码。使用过程可能会碰到如下需要手工输入 yes 的繁琐场景:

$ ssh username@hostname The authenticity of host ... can't be established. ECDSA key fingerprint is ... Are you sure you want to continue connecting (yes/no)?

为了避免出现上述场景,往 ssh 命令添加如下参数:

$ ssh -o "StrictHostKeyChecking no" username

SSH 互信

SSH 互信的配置非常简单,首先生成 ssh key:

$ ssh-keygen

把 public key 拷贝到信任方中:

$ ssh-copy-id -i ~/.ssh/id_rsa.pub username@hostname

之后免密执行命令:

$ ssh -o "StrictHostKeyChecking no" username cmd

sshpass

sshpass 是一个用于非交互的 ssh 密码验证工具,使用前先安装:

$ yum install sshpass

使用如下:

$ sshpass -p password ssh -o "StrictHostKeyChecking no" username@hostname cmd

expect

Expect 是用来进行自动化控制和测试的软件工具。虽然学习成本较高,但是 expect 的功能强大,利用 expect 可以方便的执行远程命令。使用前先安装:

$ yum install expect

例如:

#!/usr/bin/expect

spawn ssh -o "StrictHostKeyChecking no" username@hostname expect "assword" send "password " expect "$" send "command " expect "$" send "exit " expect eof

Expect 不仅支持 ssh,还支持 scp, ftp 等工具。

支持多命令和脚本

执行多条命令

sshpass 和 expect 在支持多条命令上非常类似,只需用 && 连接命令即可:

ssh trust

$ ssh -o "StrictHostKeyChecking no" username@password "cmd1 && cmd2"

例如:

sshpass

$ sshpass -p password ssh -o "StrictHostKeyChecking no" username@password "ls -a && mkdir test"

expect

...... expect "$" send "ls -a && mkdir test " ......

执行本地脚本

对于执行本地脚本,ssh 和 sshpass 的用法类似。

ssh trust

$ ssh -o "StrictHostKeyChecking no" username@password bash -s < shell_script.sh

sshpass

$ sshpass -p password ssh -o "StrictHostKeyChecking no" username@password bash -s < shell_script.sh

对于 expect,首先需要把脚本拷贝到远程主机,然后在远程主机执行该脚本,步骤如下:

...

Copy script to remote host

spawn scp -o "StrictHostKeyChecking no" shell_script.sh username@hostname:~/ expect "assword" send "password " expect "100%" expect eof

Execute the shell script at remote host

spawn ssh -o "StrictHostKeyChecking no" username@hostname expect "assword" send "password " expect "$" send "sh shell_script.sh " ......

支持执行 sudo 命令

有些命令需要 sudo 权限才能执行,但是我们不希望重复的输入密码,我们可以把每条命令修改为如下:

cmd ---> 'echo password | sudo -S cmd'

例如:

sshpass -p password ssh -o "StrictHostKeyChecking no" username@password "echo password | sudo -S mkdir /newdir"

对于如 echo, dd 等部分命令,有时会出现如下失败场景:

$ sshpass -p password ssh -o "StrictHostKeyChecking no" username@password 'echo password | sudo -S echo hello > /newdir/newfile' bash: /newdir/newfile: 权限不够

解决办法如下:

cmd ---> 'echo password | sudo -S sh -c "cmd"'

For example

$ sshpass -p password ssh -o "StrictHostKeyChecking no" username@password 'echo WSfdl097018= | sudo -S sh -c "echo hello > /newdir/newfile"'

如果采用 expect,需要把脚本拷贝到远程主机,然后在远程主机采用 sudo 执行该脚本,相对 sshpass 更简便和健壮:

...

Copy script to remote host

spawn scp -o "StrictHostKeyChecking no" shell_script.sh username@hostname:~/ expect "assword" send "password " expect "100%" expect eof

Execute the shell script at remote host

spawn ssh -o "StrictHostKeyChecking no" username@hostname expect "assword" send "password " expect "$" send "sudo sh shell_script.sh " expect "assword" send "password " ......

转载于:https://my.oschina.net/hensemlee/blog/1647401

你可能感兴趣的文章
如何用数学课件制作工具画角平分线
查看>>
《高性能mysql》到手
查看>>
(转)关于如何学好游戏3D引擎编程的一些经验
查看>>
F. Multicolored Markers(数学思维)
查看>>
nodjs html 转 pdf
查看>>
MD5加密
查看>>
微信,想要说爱你,却没有那么容易!
查看>>
WSDP
查看>>
Memory Management
查看>>
JQUERY 对 表格中的数据重排序
查看>>
Android网络框架实现之【Retrofit+RxJava】
查看>>
Android文件的加密与解密
查看>>
java笔记:SpringSecurity应用(二)
查看>>
php记录代码执行时间
查看>>
简简单单几段代码让自己变成最合格的网站管理员
查看>>
[置顶] 遵循Java EE标准体系的开源GIS服务平台之二:平台部署
查看>>
Java递归算法——阶乘
查看>>
Multi-voltage和power gating的实现
查看>>
解决Mac启动Eclipse Memory Analyzer报错问题
查看>>
连接池并发的实现原理
查看>>