前言
相信大家在工作的時(shí)侯,可能會(huì)遇到要利用 ssh 在本地執(zhí)行遠(yuǎn)程機(jī)器的命令可以便捷地處理某些重復(fù)工作,我們希望做到:
- 免手工輸入密碼
- 支持執(zhí)行多個(gè)命令,執(zhí)行 shell 腳本
- 支持執(zhí)行 sudo 的命令
免手工輸入密碼
我們可以使用 ssh 互信,sshpass 和 expect 等工具來(lái)避免手工輸密碼。
使用過(guò)程可能會(huì)碰到如下需要手工輸入 yes 的繁瑣場(chǎng)景:
$ 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)?
為了避免出現(xiàn)上述場(chǎng)景,往 ssh 命令添加如下參數(shù):
$ ssh -o "StrictHostKeyChecking no" username@password
SSH 互信
SSH 互信的配置非常簡(jiǎn)單,首先生成 ssh key:
把 public key 拷貝到信任方中:
$ ssh-copy-id -i ~/.ssh/id_rsa.pub username@hostname
之后免密執(zhí)行命令:
$ ssh -o "StrictHostKeyChecking no" username@password cmd
sshpass
sshpass 是一個(gè)用于非交互的 ssh 密碼驗(yàn)證工具,使用前先安裝:
使用如下:
$ sshpass -p password ssh -o "StrictHostKeyChecking no" username@hostname cmd
expect
Expect 是用來(lái)進(jìn)行自動(dòng)化控制和測(cè)試的軟件工具。雖然學(xué)習(xí)成本較高,但是 expect 的功能強(qiáng)大,利用 expect 可以方便的執(zhí)行遠(yuǎn)程命令。使用前先安裝:
例如:
#!/usr/bin/expect
spawn ssh -o "StrictHostKeyChecking no" username@hostname
expect "*assword*"
send "password\n"
expect "*$*"
send "command\n"
expect "*$*"
send "exit\n"
expect eof
Expect 不僅支持 ssh,還支持 scp, ftp 等工具。
支持多命令和腳本
執(zhí)行多條命令
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\n"
......
執(zhí)行本地腳本
對(duì)于執(zhí)行本地腳本,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
對(duì)于 expect,首先需要把腳本拷貝到遠(yuǎn)程主機(jī),然后在遠(yuǎn)程主機(jī)執(zhí)行該腳本,步驟如下:
...
# Copy script to remote host
spawn scp -o "StrictHostKeyChecking no" shell_script.sh username@hostname:~/
expect "*assword*"
send "password\n"
expect "*100%*"
expect eof
# Execute the shell script at remote host
spawn ssh -o "StrictHostKeyChecking no" username@hostname
expect "*assword*"
send "password\n"
expect "*$*"
send "sh shell_script.sh\n"
......
支持執(zhí)行 sudo 命令
有些命令需要 sudo 權(quán)限才能執(zhí)行,但是我們不希望重復(fù)的輸入密碼,我們可以把每條命令修改為如下:
cmd ---> 'echo password | sudo -S cmd'
例如:
$ sshpass -p password ssh -o "StrictHostKeyChecking no" username@password "echo password | sudo -S mkdir /newdir"
對(duì)于如 echo, dd 等部分命令,有時(shí)會(huì)出現(xiàn)如下失敗場(chǎng)景:
$ sshpass -p password ssh -o "StrictHostKeyChecking no" username@password 'echo password | sudo -S echo hello > /newdir/newfile'
bash: /newdir/newfile: 權(quán)限不夠
解決辦法如下:
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,需要把腳本拷貝到遠(yuǎn)程主機(jī),然后在遠(yuǎn)程主機(jī)采用 sudo 執(zhí)行該腳本,相對(duì) sshpass 更簡(jiǎn)便和健壯:
...
# Copy script to remote host
spawn scp -o "StrictHostKeyChecking no" shell_script.sh username@hostname:~/
expect "*assword*"
send "password\n"
expect "*100%*"
expect eof
# Execute the shell script at remote host
spawn ssh -o "StrictHostKeyChecking no" username@hostname
expect "*assword*"
send "password\n"
expect "*$*"
send "sudo sh shell_script.sh\n"
expect "*assword*"
send "password\n"
......
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
您可能感興趣的文章:- Windows上SSH服務(wù)器配置圖文教程
- windows 7架設(shè)OpenSSH服務(wù)器實(shí)踐
- python通過(guò)ssh-powershell監(jiān)控windows的方法
- Windows系統(tǒng)下安裝Python的SSH模塊教程
- windows7下安裝php的php-ssh2擴(kuò)展教程
- ssh遠(yuǎn)程執(zhí)行命令方法和Shell腳本實(shí)例
- ssh自動(dòng)登錄的4種實(shí)現(xiàn)方法
- python paramiko實(shí)現(xiàn)ssh遠(yuǎn)程訪問(wèn)的方法
- Python實(shí)現(xiàn)建立SSH連接的方法
- 簡(jiǎn)單架設(shè)SSH+Squid代理服務(wù)器的自由上網(wǎng)通道的方法
- 關(guān)于ssh連不上問(wèn)題的解決方法(必看)
- SSH框架網(wǎng)上商城項(xiàng)目第30戰(zhàn)之項(xiàng)目總結(jié)(附源碼下載地址)
- SSH+Jquery+Ajax框架整合
- Ubuntu下查看ssh服務(wù)是否安裝或啟動(dòng)的方法
- ssh連接超時(shí)解決方法
- PowerShell小技巧之嘗試ssh登錄
- shell腳本實(shí)現(xiàn)ssh自動(dòng)登錄功能分享
- linux系統(tǒng)下的ssh登錄和配置方法
- Linux ssh遠(yuǎn)程連接斷開(kāi)問(wèn)題處理辦法解決
- python使用paramiko模塊實(shí)現(xiàn)ssh遠(yuǎn)程登陸上傳文件并執(zhí)行
- 無(wú)需密碼通過(guò)ssh執(zhí)行rsync來(lái)同步文件的方法
- ubuntu16.04下安裝openssh-server報(bào)依賴錯(cuò)誤的完美解決方法(非常不錯(cuò))
- windows安裝openssh并通過(guò)生成SSH密鑰登錄Linux服務(wù)器