远程安装软件(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阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容