遠程安裝軟件(2):expect免輸密碼

接著上篇,version1只是實現了簡單的功能,但是易用性還有待提高,我們來看看有什么可以改進的地方

可改進點

  1. version1實現的需要用戶輸入兩次密碼(scp和ssh),如何能在執行腳本的時候免交互
  • 思路1:使用秘鑰文件
    考慮過后不可行,因為此工具的目的就是安裝軟件,只需執行一次,如果用生成秘鑰文件的方式將會比version1更不好使用

  • 思路2:使用expect,可以不用多次輸入密碼靜默安裝,有關expect我的另一篇筆記有詳細記錄
    expect:免交互自動化ssh

  1. 協程循環,用戶沒法退出,ctrl+c不友好
  • 拆開,執行一次安裝一臺遠端機器

實現version2

有三個文件主入口文件remote_install.sh和兩個被調用文件scp_expect.sh install_expect.sh
version2使用expect實現了不用多次輸入的靜默安裝方式,但是執行expect需要執行機器先安裝expect,所以做了一點小兼容,如果機器裝了expect,則靜默安裝,如果機器沒裝expect靜默安裝失敗,則手動輸入密碼安裝

  • remote_install.sh
#!/bin/bash

function help()
{
#usage
cat << HELP
------------------------------------------------------------------------------
please input 4 parameters in order:
    1st: path of xxx package at local host,
    2nd: ip of the host which xxx will install
    3rd: root's paasword of the host you inputted just now(2nd parameter)
    4th: param4
Example:
    bash remote_install.sh /opt/test/xx.zip 192.168.0.2 YourPaasWord param4

HELP
}

function install()
{
#read -a array
array=($1 $2 $3 $4)
echo ${array[*]}

# copy package to remote host
expect scp_expect.sh ${array[0]} ${array[1]} ${array[2]}
# compatible , if there is no expect, input paasword manually
if (( $? ))
then
    scp ${array[0]} root@${array[1]}:/
fi

echo "bash setup.sh -param ${array[3]}"

# install package
expect install_expect.sh ${array[1]} ${array[2]} ${array[3]}
# compatible , if there is no expect, input paasword manually
if (( $? ))
then
    ssh root@${array[1]}  "mkdir -p /opt/test && \
        cd /opt/test && \
        cp /xx-*.zip ./ && \
        unzip xx-*.zip && \
        cd /opt/test/bin && \
        bash setup.sh -param ${array[3]} "
#    bash setup.sh -param ${array[3]} >/dev/null 2>&1 &"
fi

}

#while [ 1 ]
#do
if [ $# != 4 ]
then
    help
    exit
fi
    install $1 $2 $3 $4
    sleep 1
#done
  • scp_expect.sh
#!/usr/bin/expect
set timeout 30
set path [lindex $argv 0] 
set hostname [lindex $argv 1]  
set password [lindex $argv 2]  

spawn scp $path root@$hostname:/

expect {
    "(yes/no)?" {
        send "yes\r"
        expect "assword:"
        send "$password\r"
        }
    "assword:" {send "$password\r"}
    }

#interact
expect eof
exit
  • install_expect.sh
#!/usr/bin/expect
set timeout 30
set hostname [lindex $argv 0]  
set password [lindex $argv 1]  
set param3 [lindex $argv 2] 

spawn ssh root@$hostname "mkdir -p /opt/test && \
    cd /opt/test && \
    cp /xx-*.zip ./ && \
    unzip xx-*.zip && \
    cd /opt/test/bin && \
    bash setup.sh -param $param3 "

expect "assword:" 
send "$password\r"

expect {
    "ename:" {
        send "All\r"
        expect eof
        exit
        }
    timeout {exit}
    eof {exit}
    }

遇到的問題

  • 如何判斷expect執行失敗
cd mytestdir
if (( $? )); then rm * ; fi

可改進點

明文輸入密碼不夠安全,可參考如下方式解決輸入密碼界面不顯示問題

#!/bin/bash  
echo -n "Please enter your password:"  
stty -echo  
read password  
echo -e "\nyou password is:$password"  
stty echo  

Reference:
http://blog.csdn.net/wang7dao/article/details/7724917
http://blog.csdn.net/qingsong3333/article/details/77542921

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,533評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,055評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,365評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,561評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,346評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,889評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,978評論 3 439
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,118評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,637評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,558評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,739評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,246評論 5 355
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,980評論 3 346
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,362評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,619評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,347評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,702評論 2 370

推薦閱讀更多精彩內容