Centos expect spawn、linux expect 用法


使用expect實現自動登錄的腳本,網上有很多,可是都沒有一個明白的說明,初學者一般都是照抄、收藏。可是為什么要這么寫卻不知其然。本文用一個最短的例子說明腳本的原理。 
  腳本代碼如下: 
  ############################################## 
  #!/usr/bin/expect 
  set timeout 30 
  spawn ssh -l username 192.168.1.1 
  expect "password:" 
  send "ispass\r" 
  interact 
  ############################################## 
  1. [#!/usr/bin/expect] 
  這一行告訴操作系統腳本里的代碼使用那一個shell來執行。這里的expect其實和Linux下的bash、windows下的cmd是一類東西。 
  注意:這一行需要在腳本的第一行。 
  2. [set timeout 30] 
  基本上認識英文的都知道這是設置超時時間的,現在你只要記住他的計時單位是:秒 
  3. [spawn ssh -l username 192.168.1.1] 
  spawn是進入expect環境后才可以執行的expect內部命令,如果沒有裝expect或者直接在默認的SHELL下執行是找不到spawn命令的。所以不要用 “which spawn“之類的命令去找spawn命令。好比windows里的dir就是一個內部命令,這個命令由shell自帶,你無法找到一個dir.com 或 dir.exe 的可執行文件。 
  它主要的功能是給ssh運行進程加個殼,用來傳遞交互指令。 
  4. [expect "password:"] 
  這里的expect也是expect的一個內部命令,有點暈吧,expect的shell命令和內部命令是一樣的,但不是一個功能,習慣就好了。這個命令的意思是判斷上次輸出結果里是否包含“password:”的字符串,如果有則立即返回,否則就等待一段時間后返回,這里等待時長就是前面設置的30秒 
  5. [send "ispass\r"] 
  這里就是執行交互動作,與手工輸入密碼的動作等效。 
  溫馨提示: 命令字符串結尾別忘記加上“\r”,如果出現異常等待的狀態可以核查一下。 
  6. [interact] 
  執行完成后保持交互狀態,把控制權交給控制台,這個時候就可以手工操作了。如果沒有這一句登錄完成后會退出,而不是留在遠程終端上。如果你只是登錄過去執行 
  #!/usr/bin/expect #注意安裝的路徑,不確定 whereis expect 一下 
  # Change a login shell to bash 
  set user [lindex $argv 0] 
  spawn bash $user 
  expect "]:" 
  send "/bin/bash " 
  expect eof 
  exit

 

使用expect自動登錄

一,什么是expect?
在做系統管理時,我們很多時候需要輸入密碼,例如:連接 ssh,連接ftp,
那么如何能做到不輸入密碼嗎?
我們需要有一個工具,能代替我們實現與終端的交互,
那么,就是它:expect,管理員的最好的朋友之一 
它能夠代替我們實現與終端的交互,我們不必再守候在電腦旁邊輸入密碼,
或是根據系統的輸出再運行相應的命令,
這些都可以由expect代替我們來完成

說明:expect到底是什么?
expect是一種腳本語言,使用起來非常簡單,我們看后面的例子即可以了解到了

三,安裝expect

備注:因為expect是基於tcl的,所以需要你的系統中安裝有tcl
如何檢查?
[root@dev ~]# whereis tcl
tcl: /usr/lib/tcl8.4 /usr/share/tcl8.4
如果看不到結果,請先安裝tcl
安裝,
[root@dev ~]# yum install expect
也可以從http://rpm.pbone.NET下載for相應發行版的rpm包

四,使用expect自動登錄的例子
1,程序例子的內容 :
先做功能 上的說明
此程序ssh登錄到作為參數傳遞過來的ip地址上
然后執行: df -h
free -m
uptime
來檢查系統的情況


[root@dev ~]# cat monitor_auto
#!/usr/bin/expect -f

#-------------------------------------------------- about us
# product: monitorone
# Author: liuhongdi <hongdi.liu@chinafotopress.com>
# Last Modified: 2008-05-13
# version: 0.3.2
# user:this script will help you to monitor many linux(unix) machine
# license: this script is based GPL

#-------------------------------------------------- set the variable,you can modify the value

set loginuser "root" 
set loginpass {passwordonthishost}

set ipaddr [lrange $argv 0 0] 
set timeout 300
set cmd_prompt "]#|~]?"

#-------------------------------------------------- login by ssh 
spawn ssh $loginuser@$ipaddr 
set timeout 300
expect {
-re "Are you sure you want to continue connecting (yes/no)?" {
send "yes\r"
} -re "assword:" {
send "$loginpass\r"
} -re "Permission denied, please try again." {
exit
} -re "Connection refused" {
exit
} timeout {
exit
} eof {
exit
}
}

expect {
-re "assword:" {
send "$loginpass\r"
}
-re $cmd_prompt {
send "\r"
}
}

#---------------------------------------------------- now,we do some commands
exec sleep 1
expect {
-re $cmd_prompt {
send "df -h\r"
}
}

exec sleep 1
expect { 
-re $cmd_prompt { 
send "free -m\r"
}
}

exec sleep 1
expect {
-re $cmd_prompt {
send "uptime\r"
}
}
exec sleep 1


#--------------------------------------------------
expect {
-re $cmd_prompt {
send "exit\r"
}
}


exit
#interact

2,程序 運行的顯示結果

[root@dev ~]# ./monitor_auto 209.209.94.107
spawn ssh root@209.209.94.107
root@209.209.94.107's password: 
Last login: Sun Feb 15 01:42:39 2009 from 201.103.105.49

[root@ws ~]# 
[root@ws ~]# df -h
Filesystem ÈÝ ÒÑÓÃ ¿ÉÓÃ ÒÑÓÃ% ¹ÒÔصã
/dev/mapper/VolGroup00-LogVol00
133G 72G 55G 57% /
/dev/sda1 99M 13M 82M 14% /boot
none 1014M 0 1014M 0% /dev/shm
209.209.94.109:/www/pics
5.9T 5.6T 138G 98% /bank/bank1
[root@ws ~]# free -m
total used free shared buffers cached
Mem: 2026 1955 71 0 72 1621
-/+ buffers/cache: 261 1764
Swap: 1983 68 1915
[root@ws ~]# uptime
01:48:00 up 561 days, 8:53, 2 users, load average: 0.13, 0.09, 0.07
[root@ws ~]# [root@dev ~]# 


四,對此程序的詳細說明:
1,set loginuser "root" 
set用來定義變量,定義之后的代碼中可以使用所定義的變量
使用時注意需添加$符號
使用時的例子: spawn ssh $loginuser@$ipaddr 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM