Linux命令--expect spawn的用法(实现人机交互自动化操作)
Except命令适用于人机交互场景进行使用,是处理交互的常用命令,可以将交互的过程写成一个脚本,通过调用脚本完成自动化过程;2、适用场景:ssh登录,ftp登录等二、基本语法1、Except关键的四个命令:spawn:启动新的进程expect:从进程接收字符串send:用于向进程发送字符串interact:允许用户交互2、三、实战详解...
文章共1,388字 · 阅读需要大约5分钟
一键AI生成摘要,助你高效阅读
问答
·
一、作用
1、Except命令适用于人机交互场景进行使用,是处理交互的常用命令,可以将交互的过程写成一个脚本,通过调用脚本完成自动化过程;
2、适用场景:ssh登录,ftp登录等
二、基本语法
1、Centos可以通过如下命令快速安装expect组件:
yum -y install except
-y参数:对所有的提问都回答“yes”
2、Except关键命令解析:
spawn:启动新的进程
expect:从进程接收字符串
send:用于向进程发送字符串
interact:允许用户交互
3、基本用法
- 首行
/usr/bin/expect
,声明使用except组件,类似/bin/sh用法 - spawn: spawn + 需要执行的shell命令
- expect: 只有spawn执行的命令结果才会被expect捕捉到,因为spawn会启动一个进程,只有这个进程的相关信息才会被捕捉到,主要包括:标准输入的提示信息,eof和timeout。
- send和send_user:send会将expect脚本中需要的信息发送给spawn启动的那个进程,而send_user只是回显用户发出的信息,类似于shell中的echo而已。
三、实战详解
案例1
1、实现远程拷贝文件到本地机器里
#/user/bin/expect
spawn scp -P 22 -r root@192.128.75.128:/etc/* /var/jenkins_home/
expect{
"(yes/no)?"{
send "yes\n"
expect "*password:"{
send "admin@123\n"
}
}
"*password:"{
send "admin@123\n"
}
}
expect "100%"
expect eof
2、基于key的expect自动化脚本
1、使用dsa算法:
ssh-keygen -t dsa # 使用dsa算法生成密钥,默认id_rsa
2、ssh指定密钥地址,并进行加密:(防止私钥被偷走场景)
ssh-keygen -p -f id_dsa
验证加密场景:
ssh ip地址
3、可以使用启用代理的方式,避免重复输入口令:
ssh-agent bash # 启用代理
ssh-add # 将加密口令添加到代理,窗口关闭后需要重新启动
4、通过脚本执行基于key验证,管理多台机器的expect脚本:
ssh-keygen -t rsa -P "" -f /root/.ssh/id_rsa
[root@VM-4-16-centos ssh_22]# cat ssh_key.sh
#!/bin/bash
PASS=实际密码
ssh-keygen -t rsa -P "" -f /root/.ssh/id_rsa &> /dev/null && echo "ssh key is created"
rpm -q expect &> /dev/null || yum -y install expect &> /dev/null
while read IP;do
expect << EOF
set timeout 20
spawn ssh-copy-id -i /root/.ssh/id_rsa.pub root@$IP
expect {
"yes/no" { send "yes\n" }
"password" { send "$PASS\n" }
}
expect eof
EOF
echo $IP is read
done < hosts.txt
或者
[root@157 ~]# vim selinux_disabled.sh
#! /usr/bin/expect
# 1.make sure expect exist!
rpm -q expect &> /dev/null
if [ $? -ne 0 ];then
yum -y install expect
fi
# 2.make sure public key exist!
password='xxx'
if [ ! -f ~/.ssh/id_rsa ];then
ssh-keygen -P "" -f ~/.ssh/id_rsa
fi
# 3.interactive process
for i in {178..180}
do
{
ip=192.168.8.$i
ping -c1 -W1 $ip &> /dev/null
if [ $? -eq 0 ];then
echo "$ip" >> hosts.txt
/usr/bin/expect <<- EOF
set timeout 10
spawn ssh-copy-id $ip
expect {
"yes/no" { send "yes\r"; exp_continue }
"password:" { send "$password\r" }
}
expect eof
EOF
fi
}&
done
wait
echo "ssh-key is finished"
5、集群环境内的所有的主机共用一套公钥和私钥:实现所有主机之间可以互连
ssh-copy-id -i .ssh/id_rsa.pub 127.0.0.1 # 公钥复制到自己的主机上
scp -r /root/.ssh/ 60.205.200.249:/root/ # 拷贝ssh到目标主机上
4、ssh-keygen命令
ssh-keygen(选项) - - 为ssh生成、管理和转换认证密钥
-f:指定用来保存密钥的文件名;
-P:提供(旧)密语;
-t:指定要创建的密钥类型。
更多推荐
已为社区贡献2条内容
所有评论(0)