91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Shll編程之Expect免交互

發布時間:2020-03-22 23:36:34 來源:網絡 閱讀:316 作者:JarryZ 欄目:系統運維

Shll編程之Expect免交互

1.Expect概述

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

3.Expect基本命令

4.Expect執行方式

5.Expect案例

Expect概述:

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

2.在linux運維和開發中,我們經常需要遠程登錄服務器進行操作,登錄的過程是一個交互的過程,可能會余姚輸入yes/no password等信息。為了模擬這種輸入,可以使用Expect腳本。

Expect安裝

1.掛載光盤

2.制作本地YUM源

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

基本命令:

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
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

古丈县| 扶余县| 宁波市| 阿拉善盟| 奉节县| 天峨县| 西和县| 收藏| 塔河县| 上杭县| 金门县| 松滋市| 英山县| 辉县市| 寿宁县| 辛集市| 叶城县| 罗平县| 凤山县| 通榆县| 栾城县| 连州市| 藁城市| 阳江市| 四会市| 普兰店市| 岚皋县| 磐石市| 炎陵县| 贵德县| 马公市| 光泽县| 南汇区| 云霄县| 涟水县| 阿城市| 泰来县| 凤阳县| 彭山县| 郓城县| 七台河市|