expect命令在linux下實現(xiàn)批量ssh免密
有時候我們需要批量發(fā)送ssh命令給服務器,但是有可能有些服務器是新加入的,還沒有配置ssh免密,這個時候就會提示我們輸入yes/no 或者password等,expect腳本命令就是用于在提示這些的時候,自動為我們輸入相應的文字.
expect腳本
先看一段shell腳本,實現(xiàn)了ssh自動連接
#!/usr/bin/expect
spawn ssh 192.168.1.241
expect "password"
send "123456\r"
expect "]#" {send "ls -la\r"}
interact
注意第一行使用的是#!/usr/bin/expect而不是普通的bash腳本那樣
spawn就是用來啟動新的進程
expect “password" ,注意這個是expect腳本里面內(nèi)部的命令,代表用來等待進程反饋,可以接受字符串和正則表達式,這段的意思就是將spawn啟動的進程的輸出當作expect命令的輸入,如果包含password腳本,就會向著標準輸出 輸出123456\r
,注意\r代表換行,跟我們輸入完一個命令換行是一個道理。
send:發(fā)送交互值,代替我們手動輸入
接著我們進入了241的服務器里面, 窗口會輸出[root@hadoop01 ~]# ,跟我們的]# 匹配上了,于是向控制臺輸出 ls -la命令并且換行。這里我們的expect后面是帶了大括號,跟上面的寫在兩行的效果一直。可以理解為另一種寫法。
interact的作用很特殊,代表等待spawn命令結(jié)束,并且停留在241服務端進行繼續(xù)交互,如果沒有這個,那么有可能expect對應的剛匹配上還沒執(zhí)行send就已經(jīng)結(jié)束了。對應的我們可以使用expect eof,替代interact代表等待spawn結(jié)束后退出(在spawn進程結(jié)束后會向expect發(fā)送eof)
多分支語法
上面的這種expect屬于單一分支模式,代表就匹配這一種,如果匹配的不是,那么就要自己輸入了,但是我們有可能在第一次有不同的提示,這個時候就需要使用多分支語法
expect 只要匹配到aaa 或者password其中的一種就會輸出。
#!/usr/bin/expect
spawn ssh 192.168.1.241
expect {
"aaa" {send "bbb\r"}
"password" { send "nf123456\r"}
}
expect "]#" {send "ls -la\r"}
interact
expect命令行參數(shù)
上面的expect腳本功能可能都達到了,為了避免有很多expect腳本,我更推薦使用expect命令
#!/bin/bash
SERVER="192.168.1.241"
PASSWD=nf123456
expect -c "
set timeout -1;
spawn ssh $SERVER;
expect {
\"yes/no\" { send \"yes\r\" ;exp_contine; }
\"password:\" { send \"$PASSWD\r\"; }
};
expect \"]#\" { send \"ls -la \r\" };
expect \"]#\" { send \"exit \r\" };
expect eof;
"
上面的shell功能和expect腳本實現(xiàn)的功能一致,都是通過ssh登錄進去后輸入,ls -la 命令
set timeout -1 設(shè)置超時時間
expect 后面需要加上-c
expect 命令用“雙引號包圍起來的,這點要注意
里面如果有”需要用\"轉(zhuǎn)義。
第15行代表ls -la 命令結(jié)束后發(fā)送一個退出命令,一般需要加上,防止阻塞
expect eof 匹配spawn結(jié)束
ssh批量免密demo
#!/bin/bash
SERVERS="192.168.1.241 192.168.1.242"
PASSWD="123456"
function sshcopyid
{
expect -c "
set timeout -1;
spawn ssh-copy-id $1;
expect {
\"yes/no\" { send \"yes\r\" ;exp_contine; }
\"password:\" { send \"$PASSWD\r\";exp_continue; }
};
expect eof;
"
}
for server in $SERVERS
do
sshcopyid $server
done
以上就是本次介紹的expect命令在linux下實現(xiàn)批量ssh免密的全部過程,希望能夠幫助到你。
相關(guān)文章
虛擬機中Linux新手入門配置IP以及重啟網(wǎng)絡(luò)
這篇文章主要為大家詳細介紹了虛擬機中Linux新手入門配置IP以及重啟網(wǎng)絡(luò)的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-03-03
linux Centos7斷網(wǎng)下安裝應用程序詳解
在本篇文章里小編給大家整理的是關(guān)于linux最新版本Centos7,斷網(wǎng)情況下安裝應用程序相關(guān)步驟,需要的朋友們可以學習下。2019-08-08
Linux VPS/服務器 網(wǎng)站及數(shù)據(jù)庫自動本地備份并FTP上傳備份腳本
Linux VPS/服務器 網(wǎng)站及數(shù)據(jù)庫自動本地備份并FTP上傳備份腳本的操作時怎樣進行的?如今備份已經(jīng)成為一種非常重要的操作技術(shù),掌握好數(shù)據(jù)庫備份,對大家以后的工作會很有幫助2012-05-05
Linux性能監(jiān)控工具nmon安裝及使用教程解析
這篇文章主要介紹了Linux性能監(jiān)控工具nmon安裝及使用教程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-07-07
在Linux中刪除超大(100-200GB)文件的實現(xiàn)方式
這篇文章主要介紹了在Linux中刪除超大(100-200GB)文件的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
在Linux中使用iptables設(shè)置端口轉(zhuǎn)發(fā)的步驟
在Linux系統(tǒng)中,iptables是一個非常強大的防火墻工具,用于管理網(wǎng)絡(luò)數(shù)據(jù)包的過濾和轉(zhuǎn)發(fā),它允許系統(tǒng)管理員根據(jù)特定的規(guī)則來控制數(shù)據(jù)包的流動,本文給大家介紹了如何在?Linux?中使用?iptables?設(shè)置端口轉(zhuǎn)發(fā),需要的朋友可以參考下2024-05-05
Apache中解決動態(tài)地址跳轉(zhuǎn)死循環(huán)的方法
這篇文章主要介紹了Apache中解決動態(tài)地址跳轉(zhuǎn)死循環(huán)的方法,另外作者還提出了盡量使用偽靜態(tài)的建議,需要的朋友可以參考下2015-07-07

