美文网首页
远程安装软件(2):expect免输密码

远程安装软件(2):expect免输密码

作者: 风千寻艾 | 来源:发表于2017-10-30 23:54 被阅读0次

接着上篇,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

相关文章

  • 远程安装软件(2):expect免输密码

    接着上篇,version1只是实现了简单的功能,但是易用性还有待提高,我们来看看有什么可以改进的地方 可改进点 v...

  • Command 脚本自动交互

    自动交互场景 ssh 以 密码 形式登陆远程主机时实现密码自动输入 解决方案 使用expect命令 expect ...

  • OpenVPN常用配置

    之前为实现免密码登陆OpenVPN,特意编写Expect脚本实现,后来发现有更简单的方法如正文。 免密码登陆 Li...

  • 使用expect远程登录主机

    expect就是一个脚本,以expect或者exp为后缀 安装 实例:自动远程登录 ssh远程登录一台主机后,会在...

  • rsync+ssh远程免密码增量同步资源

    远程免密码增量同步资源 一:免密码 有两台机器A和B,想在机器A上远程B,而不需要密码。步骤如下 1:生成公钥文件...

  • expect脚本使用

    expect自动化远程登录脚本 首先要安装 expect 脚本程序,不过在 Macbook 中自带了。比如 Cen...

  • linux下的expect使用

    expect介绍 expect提供自动交互的的一个工具 案列 登录远程服务器不用手工输入密码 以上脚本就ssh访问...

  • Ubuntu安装 vim ssh mysql8 jdk17

    1 安装ssh 2 远程连接 3 安装jdk,mysql 4 配置mysql密码和远程连接 修改并保存:wq 重启

  • ansible批量管理服务部署 2020-03-07

    ansible批量管理服务部署 1. 安装部署软件 2. 编写主机清单 3. 配置密钥免密码连接认证 3. 测试被...

  • ssh远程连接服务器 脚本文件 【软连接】

    一个使用expect免输入密码自动登录ssh的shell脚本,方便好用,适用Mac、Linux 来自:https:...

网友评论

      本文标题:远程安装软件(2):expect免输密码

      本文链接:https://www.haomeiwen.com/subject/eftcpxtx.html