Shell脚本------Expect(实现ssh服务免交互)

Expect基本概述

Expect是通用的,因此它可以作为用户级别的命令运行,而无需考虑任何程序和任务。Expect实际上可以同时与多个程序对话。Expect对于需要程序与用户交互的程序来说非常有用。如果有需要Expect还可以交还控制权给用户,而不需要停止被控制的程序。同样,用户也可以在任何时候将控制权返还给脚本。

常用选项

-c:在脚本中任何要执行的命令之前的命令前缀。应该用引号将命令包围起来,防止被shell破坏。此选项可以多次使用。多个命令可以用一个-c按顺序执行,用分号进行分隔(如果使用Expectk,则使用-command选项)。

-d:启用一些诊断输出,主要报告如expect和interact等命令的内部活动。此选项与“exp_internal 1”具有相同的效果。并会打印Expect的版本。例如,strace命令用于跟踪语句,trace命令用于跟踪变量赋值(如果使用Expectk,则使用-diag选项)。

-D:启用交互式调试器。后面跟一个整数值,如果值为非零值、按下了Ctrl+C、命中断点或者脚本中出现其他适当的调试器命令,调试器将在下一个Tcl过程之前保持控制权(如果使用Expectk,则使用-Debug选项)。

-f:标记在要从中读取命令的文件前面。-f本身是可选的,在命令行中,如果不提供-f,则在执行完文件中的命令后就会结束命令,会忽略后面的expect选项,如果提供-f,则不会忽略后面的expect选项。当在脚本中隐式调用expect时,如果不提供-f,则会将expect选项当作普通的位置参数。如果提供,则会尝试识别expect选项(如果使用Expectk,则使用-file选项)。

-b:强制一行一行地读取文件并执行。默认情况下,命令文件被读入内存并全部执行(如果使用Expectk,则使用-buffer选项)。 如果提供给-f与-b的文件名是“-”,则会从标准输入读取。

-i:expect以交互方式提示输入命令,而不是从文件中读取命令。提示通过exit命令或EOF终止。如果不使用命令文件或

-c,则默认使用-i(如果使用Expectk,则使用-interactive选项)。

--:用来分隔选项的末尾。对于传递不想被expect解释的类似选项的参数的情况非常有用。--后面的参数不会被尝试解析为expect选项。--同样可以与#!一起使用。在遇到第一个非expect选项开始后面的所有选项都会作为普通参数解析。

-N:禁止expect自动获取$exp_library/expect.rc文件,如果文件存在(如果使用Expectk,则使用-NORC选项)。

-n:在$exp_library/expect.rc之后,禁止expect自动获取~/.expect.rc文件,如果文件存在(如果使用Expectk,则使用-norc选项)。如果定义了环境变量DOTDIR,则会从其指定位置获取.expect.rc文件。

-v:打印expect版本号(如果使用Expectk,则使用-version选项)。

args:可选的args构造成一个列表,并保存在变量argv中。变量argc初始化为argv的长度。argv0被定义为脚本的名称。

示例

Expect直接和 嵌入
1、使用expect通过直接编写的方法实现ssh服务免交互

#!/usr/bin/expect
set timeout 20   //超时时间
//参数传入
set hostname [lindex $argv 0]
set password [lindex $argv 1]
//追捕命令
spawn ssh [email protected]$hostname
//追捕到信息并执行免交互
expect {
        "(yes/no)"
        {send "yes\r";exp_continue}
        "*password"
        {send "$password\r"}
}
//将执行权限交给控制台输出
interact
[[email protected] ~]# chmod +x expect.sh  //给脚本添加执行权限
[[email protected] ~]# ./expect.sh 192.168.100.137 qweqwe //执行脚本并输入ssh登录用户的ip和登录密码
//执行脚本的结果
spawn ssh [email protected]
The authenticity of host ‘192.168.100.137 (192.168.100.137)‘ can‘t be established.
ECDSA key fingerprint is SHA256:nbnd6568zTp0Fgdo2gavS4YXLySyTvs7+JT/b7L/syU.
ECDSA key fingerprint is MD5:0d:02:8f:c9:28:e3:41:30:f7:fd:94:94:2d:ff:ff:dd.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added ‘192.168.100.137‘ (ECDSA) to the list of known hosts.
[email protected]‘s password:
Last login: Fri Oct 11 17:02:57 2019 from 192.168.100.1

输入"ipconfig"查看当前登录用户ip地址是否为192.168.100.137

如果想要等出的话,输入"exit"命令即可等出当前用户

[[email protected] ~]# exit
登出

2、使用expect嵌入编写的方式实现ssh服务免交互

#!/bin/bash
hostname=$1
password=$2

/usr/bin/expect <<-EOF 

spawn ssh [email protected]$hostname

expect {
        "(yes/no)"
        {send "yes\r";exp_continue}
        "*password"
        {send "$password\r"}
}
expect "*]#"
send "exit\r"
expect eof
EOF

执行脚本结果

[[email protected] ~]# chmod +x expect1.sh
[[email protected] ~]# ./expect1.sh 192.168.100.137 qweqwe

原文地址:https://blog.51cto.com/14307755/2442713

时间: 2025-01-15 08:46:01

Shell脚本------Expect(实现ssh服务免交互)的相关文章

使用Shell脚本+expect批量部署ssh

Shell脚本+expect批量部署ssh一.准备工作及思路1,三台机器做实验(centos6.5.IP:192.168.0.22 (主控制).192.168.0.156.192.168.0.157)2,IP:22这一台做主控机器,另外2台做客户机.3,提前在主控制机器上创建好公钥,安装好expect,使用脚本批量推送ssh公钥.4,本次部署是以root身份进行下面的操作.二.正式部署1,首先穿件秘钥[[email protected] .ssh]# ssh-keygen -t rsa Gene

shell脚本批量部署ssh

日常运维工作中,需要给几十上百台服务器批量部署软件或者是重启服务器等操作, 这样大量重复性的工作一定很苦恼,本文给大家提供了最基本的批量操作的方法,虽然效率不高,对于初学者来说还是好理解.由于刚开始学习写脚本,什么 puppt这样的高级工具还不会使用,就简单的利用shell脚本.ssh-keygen.expect来实现.希望能给各位带来帮助,不足之处还请留言 指出,大家共同进步. 首先,需要检查expect是否安装:rpm -qa|grep expect 然后,在操作机上创建公钥:ssh-key

用shell脚本自动化部署dhcp服务,加图文验证

自动化dhcp服务shell脚本如下: #vim auto_dhcp.sh #!/bin/bash read -p "please input your ip: " IP     #设置dhcp服务器ip read -p "please input your gw: " GW     #设置dhcp服务器网关 IPNET=$(echo $IP |awk -F. '{print $1"."$2"."$3}')  #取网段号  I

【高效率】shell脚本一键安装Tomcat服务

脚本环境 1.linux centos 7或redhat 62.光盘镜像文件已挂载3.系统在可连接外网的环境中4.先下载jdk和tomcat软件包百度云链接提取码:89be 实验步骤 1.上传软件包到Linux系统中2.编写脚本vim tomcat.sh #!/bin/bash#this is tomcat shell #先关闭防火墙,增强性systemctl stop firewalldsetenforce 0num1=`env | grep USER | grep root | wc -l

shell脚本之不同系统上ftp交互使用

场景:当公司将有文件要自动将ubuntu系统的文件要上传到windows上面,或者windows上的文件要下载到ubuntu上面,尤其是像什么日志啊,编译结果啊,测试结果啊等等,做个备份或者做分析处理等. 下面是shell脚本模板: !/bin/bash #上传文件 ftp -v  -niv  <<EOF                                  #EOF附件没有空格,不然会报错 open  192.168.1.1                            

Shell脚本:使用SSH登陆并更改密码

平时运维中有时会遇到需要更改服务器的管理员密码,如果服务器比较多的时候,我们可以编写一个脚本来实现,省时省力. linux使用SSH登陆时需 要手动输入yes 来确认连接,所以首先要解决这个问题,让脚本实现远程执行命令无须人工干预. 第一步 使用ssh-keygen创建本机的公钥和私钥 创建成功后会在/root/.ssh下生成私钥和公钥 第二步 使用ssh-copy-id复制公钥到远程主机及expect内部命令编写ssh自动登陆脚本 auto_ssh_copy_id () { expect -c

shell脚本--expect自动应答

expect自动应答  TCL语言 需求1:远程登录到A主机,什么事情也不做 #! /usr/bin/env expect # 开启一个程序 spawn ssh [email protected]192.144.213.113 # 捕获相关内容 expect { "(yes/no)?" { send "yes\r";exp_continue } "password:" { send "Lzw18519331036\r" } }

shell脚本:监控MySQL服务是否正常

监控MySQL服务是否正常,通常的思路为:检查3306端口是否启动,ps查看mysqld进程是否启动,命令行登录mysql执行语句返回结果,php或jsp程序检测(需要开发人员开发程序)等等: 方法1:监听3306端口 #!/bin/bash #written by [email protected] port=`netstat -nlt|grep 3306|wc -l` if [ $port -ne 1 ] then  /etc/init.d/mysqld start else  echo "

shell脚本 expect 实现自动登陆

vi auto_ssh.exp #!/usr/bin/expect set ipaddress "123.227.159.159" set passwd "你的密码" set timeout 30 spawn ssh [email protected]$ipaddress expect { "yes/no" {send "yes\r";exp_continue} "password" {send "