自動ssh登入的幾種方法 升級教程shell 指令碼 自動化

來源:互聯網
上載者:User

原文連結

 

之前採用sshpass 參見

shell 指令碼 自動化

 

自動ssh登入的幾種方法 1. 自動ssh/scp方法==

A為本地主機(即用於控制其他主機的機器) ;
B為遠程主機(即被控制的機器Server), 假如ip為192.168.60.110;
A和B的系統都是Linux

在A上運行命令:
# ssh-keygen -t rsa (連續三次斷行符號,即在本地產生了公開金鑰和私密金鑰,不設定密碼)
# ssh root@192.168.60.110 "mkdir .ssh" (需要輸入密碼)
# scp ~/.ssh/id_rsa.pub root@192.168.60.110:.ssh/id_rsa.pub (需要輸入密碼)

在B上的命令:
# touch /root/.ssh/authorized_keys (如果已經存在這個檔案, 跳過這條)
# cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys (將id_rsa.pub的內容追加到authorized_keys 中)

回到A機器:
# ssh root@192.168.60.110 (不要求輸入密碼, 登入成功) 

2. 控制n個機器如上所述自動登入
那就需要n對鑰匙(密鑰和公開金鑰), ssh-keygen 命令可以隨意更改鑰匙對的名字, 比如:
# ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): /root/.ssh/id_rsa_192.168.60.110

這樣私密金鑰和公開金鑰的名字分別就是: id_rsa_192.168.60.110和 id_rsa_192.168.60.110.pub;然後將 id_rsa_192.168.60.110.pub 檔案的內容, 追加到sever的 ~/.ssh/authorized_keys檔案中,最後, 在本地用ssh命令的 -i 參數指定本地密鑰, 並登入:
# ssh -i /root/.ssh/id_rsa_192.168.60.110 someone@192.168.60.110

scp也是一樣的
# scp -i /root/.ssh/id_rsa_192.168.60.110 filename someone@192.168.60.110:/home/someone

在檔案.bashrc中加下兩行,每次做同樣的操作就不用敲入這樣長的命令了:
alias sshcell='ssh -i /root/.ssh/id_rsa_192.168.60.110 someone@192.168.60.110'
alias scpcell='scp -i /root/.ssh/id_rsa_192.168.60.110 filename someone@192.168.60.110:/home/someone'

這樣,直接鍵入一下指令實現ssh和scp自動登入:
# sshcell
# scpcell

3. 自動ssh/scp指令碼
如果需要從A,到B,然後才能夠到C,那麼需要ssh和scp兩次,是比較麻煩的。
ssh自動登入:
#!/usr/bin/expect -f
set timeout 30
spawn ssh weiqiong@B
expect "password:"
send "pppppp/r"
expect "]*"
send "ssh weiqiong@C/r"
expect "password:"
send "pppppp/r"
interact

scp從A拷貝檔案到C:
#!/usr/bin/expect -f
set timeout 300
set file [lindex $argv 0]
spawn scp $file weiqiong@B:/home/weiqiong
expect "password:"
send "pppppp/r"
expect "]*"
spawn ssh weiqiong@B
expect "password:"
send "pppppp/r"
expect "]*"
send "scp $file weiqiong@C:/home/weiqiong/r"
expect "password:"
send "pppppp/r"
expect "]*"
exit
interact

scp從C拷貝檔案到A:
#!/usr/bin/expect -f
set timeout 300
set file [lindex $argv 0]
spawn ssh weiqiong@B
expect "password:"
send "pppppp/r"
expect "]*"
send "scp weiqiong@C:/home/weiqiong/$file ./r"
expect "password:"
send "pppppp/r"
expect "]*"
send "exit/r"
expect "]*"
spawn scp weiqiong@B:/home/weiqiong/$file .
expect "password:"
send "pppppp/r"
interact

4. 建立ssh/scp通道
比如說我的機器是A,中間伺服器為B,目標伺服器是C<br>
從A可以ssh到B,從B可以ssh到C,但是A不能直接ssh到C<br>
現在展示利用ssh通道技術從A直接傳輸檔案到C<br>
1. ssh -L1234:C:22 userid@B<br>
input B's password<br>
(1234是本機A的空閑連接埠,該指令需要A機器上的root使用者權限,實際上是在本機1234連接埠建立了一個通道)<br>

2. 開啟一個新的console,鍵入:<br>
scp -P1234 filename userid@localhost:<br>
input C's password

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.