Shll編程之Expect免交互

Shll編程之Expect免交互

1.Expect概述java

2.Expect安裝(底層語言Tcl)linux

3.Expect基本命令shell

4.Expect執行方式編程

5.Expect案例vim

Expect概述:

1.Expect是創建在tcl語言基礎上的一個工具,Expect是用來進行自動化控制和測試的工具。主要解決shell腳本中不可交互的問題。對於大規模的linux運維頗有幫助。數組

2.在linux運維和開發中,咱們常常須要遠程登陸服務器進行操做,登陸的過程是一個交互的過程,可能會餘姚輸入yes/no password等信息。爲了模擬這種輸入,可使用Expect腳本。bash

Expect安裝

1.掛載光盤服務器

2.製做本地YUM源運維

執行安裝命令:yum -y intall expectssh

基本命令:

1.send:向進程發送字符串,用於模擬用戶的輸入

該命令不能自動回車換行,通常要加\r(回車)

2.expect

expect的一個內部命令判斷上次輸出結果裏是否包含指定的字符串,若是有則當即返回,不然就等待超時時間後返回

只能捕捉由spawn啓動的進程的輸出

#####3.spawn:啓動進程,並跟蹤後續交互信息

4.interact:執行完成後保持交互狀態,把控制權交給控制檯
5.Timeout:指定超時時間,過時則繼續執行後續指令

單位是:秒

timeout -1爲永不超時

默認狀況下,timeout是10秒

6.exp_continue

容許expect繼續向下執行指令

7.send_user:

回顯命令,至關於echo

8.$argv參數數組:

Expect腳本能夠接受從bash傳遞的參數,可使用[lindex $argv n]得到,n從0開始,分別表示第一個,第二個,第三個....參數

9.Expect腳本必須以interact或expect ecof結束,執行自動化任務一般expect eof就夠了

expect eof實在等待結束標誌。由spawn啓動的命令在結束時會產生一個eof標記,expect eof即在等待這個標記

Expect執行方式:

直接執行

[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

Demo1:遠程登陸

[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

Demo2:登陸遠程控制後自動退出

[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.
//自動退出遠程控制
EOF容錯只能容製表符TAB,可是空格不行

Demo3:建立用戶tom,密碼tom123

[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用戶

SSH遠程登陸代碼健壯版

#!/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
相關文章
相關標籤/搜索