1.Expect概述java
2.Expect安裝(底層語言Tcl)linux
3.Expect基本命令shell
4.Expect執行方式編程
5.Expect案例vim
1.Expect是創建在tcl語言基礎上的一個工具,Expect是用來進行自動化控制和測試的工具。主要解決shell腳本中不可交互的問題。對於大規模的linux運維頗有幫助。數組
2.在linux運維和開發中,咱們常常須要遠程登陸服務器進行操做,登陸的過程是一個交互的過程,可能會餘姚輸入yes/no password等信息。爲了模擬這種輸入,可使用Expect腳本。bash
1.掛載光盤服務器
2.製做本地YUM源運維
執行安裝命令:yum -y intall expectssh
該命令不能自動回車換行,通常要加\r(回車)
expect的一個內部命令判斷上次輸出結果裏是否包含指定的字符串,若是有則當即返回,不然就等待超時時間後返回
只能捕捉由spawn啓動的進程的輸出
#####3.spawn:啓動進程,並跟蹤後續交互信息
單位是:秒
timeout -1爲永不超時
默認狀況下,timeout是10秒
容許expect繼續向下執行指令
回顯命令,至關於echo
Expect腳本能夠接受從bash傳遞的參數,可使用[lindex $argv n]得到,n從0開始,分別表示第一個,第二個,第三個....參數
expect eof實在等待結束標誌。由spawn啓動的命令在結束時會產生一個eof標記,expect eof即在等待這個標記
[root@ce~]#more a.sh #!/usr/bin/expect //Expect二進制文件的路徑 set timeout 60 //60秒等待時間 log_file test.log //日誌文件 log_user 1 //日誌用戶 set hostname [lindex $argv 0] //追加參數0,統計變量,加載第1位置 set password [lindex $argv 1] //追加參數1,統計變量,加載第2位置 spawn ssh root@$hostname expect { //進行匹配 "(yes/no)" {send"yes/r";exp_continue} //輸入yes,繼續執行 "*password" //參數2 {send"$password\r"} //交給控制檯人爲輸入 } interact [root@ce~]#chmod a+x a.sh [root@ce~]#./a.sh
[root@localhost opt]# yum install expect -y //安裝服務 [root@localhost opt]# vim a.sh #!/usr/bin/expect #超時時間 set timeout 20 log_file test.log log_user 1 #參數傳入 set hostname [lindex $argv 0] set password [lindex $argv 1] #追蹤命令 spawn ssh root@$hostname #捕捉信息而且匹配,免交互執行 expect { "(yes/no)" {send "yes\r";exp_continue} "*password" {send "$password\r"} } #控制權交給控制檯執行 interact [root@localhost opt]# chmod +x a.sh [root@localhost opt]# ./a.sh 192.168.56.129 123123 spawn ssh root@192.168.56.129 The authenticity of host '192.168.56.129 (192.168.56.129)' can't be established. ECDSA key fingerprint is SHA256:DSqXtMX4L3DIIYCai7ACEftdbCIH5n0Y5SPpGCzsjdw. ECDSA key fingerprint is MD5:14:93:39:65:27:31:a6:28:8b:28:d1:2c:fb:32:7b:4d. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added '192.168.56.129' (ECDSA) to the list of known hosts. root@192.168.56.129's password: Last login: Thu Oct 10 09:46:08 2019 from 192.168.56.1 //此時已遠程登陸對方主機 [root@localhost ~]# 登出 //按Ctrl+d退出遠程登陸 Connection to 192.168.56.129 closed.
[root@ce~]#more b.sh #!/bin/bash hostname=$1 password=$2 /usr/bin/expect<<-EOF spawn ssh root@${hostname} expect { "(yes/no)" {send "yes\r";exp_continue} "*password" {send"$password\r"} } expect "*]#" send "exit\r" expect eof EOF [root@ce~]#source b.sh
[root@localhost opt]# vim b.sh #!/bin/bash hostname=$1 password=$2 /usr/bin/expect<<-EOF spawn ssh root@${hostname} expect { "(yes/no)" {send "yes\r";exp_continue} "*password" {send "$password\r"} } expect "*]#" send "exit\r" expect eof EOF [root@localhost opt]# chmod +x a.sh [root@localhost opt]# ./a.sh 192.168.56.129 123123 spawn ssh root@192.168.56.129 The authenticity of host '192.168.56.129 (192.168.56.129)' can't be established. ECDSA key fingerprint is SHA256:DSqXtMX4L3DIIYCai7ACEftdbCIH5n0Y5SPpGCzsjdw. ECDSA key fingerprint is MD5:14:93:39:65:27:31:a6:28:8b:28:d1:2c:fb:32:7b:4d. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added '192.168.56.129' (ECDSA) to the list of known hosts. root@192.168.56.129's password: Last login: Thu Oct 10 09:46:08 2019 from 192.168.56.1 [root@localhost ~]# 登出 Connection to 192.168.56.129 closed. //自動退出遠程控制
[root@localhost opt]# vim c.sh #!/bin/bash user=$1 password=$2 #非交互命令放在expect外面 useradd $user #開始進行交互 expect << EOF spawn passwd $user expect "新的*" send "${password}\r" expect "從新*" send "${password}\r" expect eof; EOF [root@localhost opt]# chmod +x c.sh [root@localhost opt]# ./c.sh tom tom123 spawn passwd tom 更改用戶 tom 的密碼 。 新的 密碼: 無效的密碼: 密碼少於 7 個字符 從新輸入新的 密碼: passwd:全部的身份驗證令牌已經成功更新。 [root@localhost opt]# su zhou //切換普通用戶zhou [zhou@localhost opt]$ su tom //切換新建立的普通用戶tom 密碼: //提示輸入密碼 [tom@localhost opt]$ //此時進入tom用戶
#!/usr/bin/expect #超時時間 set timeout 20 log_file test.log log_user 1 #參數傳入 set hostname [lindex $argv 0] set password [lindex $argv 1] #追蹤命令 spawn ssh root@$hostname #捕捉信息而且匹配,免交互執行 expect { "Connection refused" exit "service not known" exit "(yes/no)" {send "yes\r";exp_continue} "*password" {send "$password\r"} } #控制權交給控制檯執行 interact exit