shell编程之免交互

目录

1、Here Document免交互

(1)Here Document概述

(2)Here Document使用注意事项

(3 )示例

 2、Expect免交户

(1)Expect概述

(2)Expect安装

 (3)基础命令

(1)expect

(2)send

(3)spawn

(4)结束符

(5)set

(6)exp_continue

(7)send_user

(8)接受参数

(4)示例

总结


1、Here Document免交互

(1)Here Document概述

■使用I/O重定向的方式将命令列表提供给交互式程序

■标准输入的一种替代品

■语法格式

命令 <<标记

...

...

标记

(2)Here Document使用注意事项

■标记可以使用任意合法字符

■结尾的标记一定要顶格写,前面不能有任何字符

■结尾的标记后面也不能有任何字符(包括空格)

■开头标记前后的空格会被省略掉

(3 )示例

1、

 2、利用read命令接受输入并打印

3、 利用passwd给用户添加密码

4、 变量进行替换:在写入文件时回显将变量替换成实际值,再结合cat命令完成写入

 

 

 5、整体赋值给变量,然后通过echo命令将变量值打印出来

 6、关闭变量替换功能,在EOF上加单引号,会直接将调用的变量直接输出变量名

 

 7、去掉每行之前的TAB字符

 

 没有加 -

 8、多行注释

Bash的默认注释是“#”,该注释方法只支持单行注释,在shekk脚本的工作中,“#”右侧的任何字符串,bash都会将其忽略。Here Document的引入解决了多行注释的问题。

“:”代表什么都不做的空命令。中间标记区域的内容不会被执行,会被bash忽略掉,因此可达到批量注释的效果。

 

 2、Expect免交户

(1)Expect概述

●建立在tcl之上的一个工具

●用于进行自动化控制和测试

●解决shell脚本中交互相关的问题

(2)Expect安装

[root@localhost ~]# yum -y install expect

[root@localhost~]#rpm -qa]grep expect

expect-5.45-14.el7_1.x86_64

[root@localhost ~]# rpm -qa]grep tcl

tcl-8.5.13-8.el7.x86_64

 (3)基础命令

(1)expect

●判断上次输出结果中是否包含指定的字符串,如果有则立即返回,否则就等待超时时间后返回

●只能捕捉由spawn启动的进程的输出

●用于接收命令执行后的输出,然后和期望的字符串匹配

(2)send

●向进程发送字符串,用于模拟用户的输入

●该命令不能自动回车换行,一般要加r(回车)

(3)spawn

spawn后面通常跟一个Linux执行命令,表示开启一个会话、启动进程,并跟踪后续交互信息。

例:spawn passwd root

(4)结束符

●expect eof(执行自动化任务通常使用expect eof)

比如切换到root用户,expect脚本默认的是等待10s,当执行完成命令后,默认停留10s后,自动切回了原用户

等待执行结束

●interact

执行完成后保持交互状态,把控制权交给控制台,会停留在目标终端而不会退回到原终端,这个时

候就可以手工操作了,interact后的命令不起作用,比如interact后添加exit,并不会退出root用

户。而如果没有interact则登录完成后会退出,而不是留在远程终端上。

使用interact会保持在终端而不会退回到原终端,比如切换到root用户,会一直在root用户状态下;

比如ssh到另一服务器,会一直在目标服务器终端,而不会切回的原服务器。

注意:expect eof 与 interact只能二选一。

(5)set

●设置超时时间,过期则继续执行后续指令

●单位是秒

●timeout -1表示永不超时

●默认情况下,timeout是10秒

(6)exp_continue

   附加于某个expect判断项之后,可以使该项被匹配后,还能继续匹配该expect-判断语句内的其他项。exp_continmue类似于控制语句中的continue 语句。表示允许expect继续向下执行指令。

例如:下例将判断交互输出中是否存在yes/no或*password。如果匹配yes/no则输出 yes并再次执行判断;如果匹配*password则输出abc123并结束该段expect语句。

expect {

" (yes/no) " { send "yeslr"; exp _continue ; }

"*password" { set timeout 300; send "abc123\r"; }

注意:使用exp continue时,如果跟踪像passwd 这样的输入密码后就结束进程的命令,expect(}外不要再加上expect eof因为spawn进程结束后会默认向expect发送eof,会导致后面的expect eof执行报错

注:表示允许用户进行交互操作,一直保持会话连接

(7)send_user

●回显命令,相当于echo

(8)接受参数

●expect脚本可以接受从bash传递的参数

●可以使用[lindex %argv n]获得

●n从0开始,分别表示第一个、第二个、第三个...参数

(4)示例

用expect编写脚本

例1:ssh无交互登录到远程服务器

[root@sjserver ~]# vim expect.sh

#!/usr/bin/expect                 //这里需要用expect自己的解释器,注意不要写成bash否则无法识别

spawn ssh root@192.168.100.100    //开启一个程序,这个程序是ssh远程登录

expect {
//捕获内容,当出现password的时候,就会向程序发送密码,默认是不换行的,所以需要\r回车换行,多个条件需要花括号括起来,注意格式问题!
    
        "password: "
        { send "123456\r"; }
}

interact                        //交互,否则会直接退出远程服务器

[root@sjserver ~]#chmod +x expect.sh    //需要加执行权限

[rootesjserver ~] # ./expect.sh

spawn ssh root@192.168.100.100root@192.168.100.100's password:

Last login: Mon Jul 27 23:31:00 2020 from 192.168.100.120
例2

如果想要在对方服务器上进行一下操作后再退出可执行以下脚本[root@localhost ~]# vim expect.sh

# ! /usr/bin/expect

spawn ssh root@192.168.245.211   需要空行

expect {

        "password: "

        { send "123456\r"; }
}

expect "#"                   //当捕获到#的时候

send "ls \r"                 //执行ls命令

send "ifconfig ens33 \r"     //执行ifconfig ens33命令

send "exit\r"                //执行完exit退出登陆

expect eof                   //不需要进行交互了,意味着结束expect程序,如果不写的话不会执行操作直接退出;如果不写,写interact也无法在对方机器上执行命令,eof可以替换

定义和引用变量
用set关键字定义变量,变量名和变量的值中间用空格分开,其他用法与shell脚本一致#!/usr/bin/expect
set user root
set ip 192.168.245.211set pass 123456

引用位置变量

# !/ usr/bin/expectset user root

set ip [lindex $argv 0]            //设置第一个位置变量为ip

set pass [lindex $argv 1]          //设置第二个位置变量为登陆密码

spawn ssh $user@$ip

expect {

             "password: "

            { send "$pass\r"; }
}

expect "#"

send "ls \r"

send "ifconfig ens33\r"

send "exit\r"

#interact

expect eof

[root@localhost ~]# ./expect.sh 192.168.245.211123456    //执行时需要加位置变量

还可以定义其他参数,例如超时时间,日志等#超时时间

set timeout 20//登陆超时多少秒退出#开启日志文件

log_file test.log//日志记录操作#显示信息

log_user 1 l/1为屏幕输出信息,0为不输出

ssh免交户登录另外一种写法

#!/usr/bin/expec

tset timeout 60

log_file test.log

log_user 1

set ip [lindex $argv 0]

set password [lindex $argv 1]

spawn ssh root@$ {ip}

expect {

" (yes/no) "

{send "yes\r"; exp_continuel "*password"
{ send "$password\r"}
}

interact

[root@localhost~]#sh expect.sh 192.168.10.20  111111

嵌入执行模式,将expect过程融入shell 当中,方便执行和处理

在shell脚本中调用expect

1、创建用户并设置用户密码例1:

#!/bin/bash

username=$1

useradd $username

/usr/bin/expecti <<-EOF

spawn passwd $username

expect {

"密码"//注意:获取的内容和发送的内容不能在同一行否则执行不成功

{send "123456\r" ;exp_continue}

"新的密码"

{ send "123456\r"; }

EOF

另一种方式

 # ! /bin/bashuser=$1

password=$2

useradd $user

expect <<EOF

spawn passwd $user      #开启一个进程跟踪passwd命令,expect只能捕捉该进程信息

expect    "新的*"              #匹配输出信息"新的*川I

send "$ {password} \r"   #自动输入密码

expect"重新*:"                 #匹配输出信息"重新*"

send "$ {password} \r"   #自动输入密码

expect eof;                       #等待结束标记

EOF

 ssh远程到服务器案列

#!/bin/bash

expect -c "        //需要用expect -c调用expect程序

spawn ssh root@192.168.245.211

expect \ "password: \" { send \ "123456\r\" }

interact
"
[root@localhost ~]# vim expects.sh                //不仅停留还要打些命令退出的情况
# !/bin/bash

expect -c "
spawn ssh root192.168.245.211

expect \ "password: \" {send \ "123456\r\"}

expect \"]# \"{ send \"ifconfig\r\"}

expect \"]#\" {send \ "exit\r\ "}expect eof

 利用expect完成 FTP登录过程
# ! /usr/bin/expect -f

set timeout 10

spawn ftp 192.168.8.33

expect "Name*"

send "ftp\r"

expect "Password:*"

send "\r"

expect "ftp>*"

interact

expect eof

总结

■Here Document使用方法

■Expect 基本命令

■Expect 使用方法

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值