Shell编程免交互及免密登录

Here Document

概述

1.使用I/O重定向的方式将命令列表提供给交互程序
2.标准输入的一种代替品

语法格式:

 命令 <<标记
 ...
 ...
 标记

注意事项

  • 标记可以使用任意合法字符
  • 结尾的标记一定要定格写,前面不能有任何字符
  • 结尾的标记后面也不能有任何字符(包括空格)
  • 开头标记前后的空格会被省略掉

read命令

[root@server2 ~]# read a
abc
[root@server2 ~]# echo $a
abc
[root@server2 ~]# vi z.sh
#!/bin/bash
# read免交互
read z <<DD
abc
DD
echo $z
[root@server2 ~]# chmod +x z.sh 
[root@server2 ~]# ./z.sh 

在这里插入图片描述

Here Document变量

变量替换

[root@server2 ~]# vi file.sh
#!/bin/bash
# 查看内容重定向给一个文件
a=/root/a.txt
b=abc
cat > $a << EOF
nihao $b
EOF
[root@server2 ~]# chmod +x file.sh 
[root@server2 ~]# ./file.sh 
[root@server2 ~]# cat a.txt

在这里插入图片描述

变量设定

[root@server2 ~]# vi fuzi.sh
#!/bin/bash
# 多行内容赋值给变量
fuz=a
b=$(cat << EOF       多行内容整合为一个整体    
it is a apple.
this is a tree.
$fuz
EOF
)
echo $b
[root@server2 ~]# chmod +x fuzi.sh 
[root@server2 ~]# ./fuzi.sh 

在这里插入图片描述

Here Document格式控制

关闭变量替换功能

[root@server2 ~]# vi fuzi.sh
#!/bin/bash
# 多行内容赋值给变量
fuz=a
b=$(cat <<'EOF'
it is a apple.
this is a tree.
$fuz
EOF
)
echo $b
[root@server2 ~]# chmod +x fuzi.sh 
[root@server2 ~]# ./fuzi.sh 

在这里插入图片描述

去除每行之前的TAB字符

[root@server2 ~]# vi fuzi.sh
#!/bin/bash
# 多行内容赋值给变量
fuz=a
b=$(cat <<-'EOF'
        it is a apple.
        this is a tree.
        $fuz
        EOF
)
echo $b
[root@server2 ~]# chmod +x fuzi.sh 
[root@server2 ~]# ./fuzi.sh 

在这里插入图片描述

Here Document多行注释

语法格式

:<<DO-NOTHING
第一行注释
第二行注释

DO-NOTHING

示例

[root@server2 ~]# vi test.sh
#!/bin/bash
# 注释
:<<AA
hello
good
zjq
AA
echo jq
[root@server2 ~]# chmod +x test.sh 
[root@server2 ~]# ./test.sh 

在这里插入图片描述

Expect

概述

  • 建立在tcl(基本语言工具)之上的一个工具
  • 用于进行自动化控制和测试(屏幕捕捉)
  • 解决shell脚本中交互相关的问题
  • 1.spawn

启动进程,并跟踪后续交互信息

  • 2.expect

判断上次输出结果中是否包含指定的字符串,如果有则立即返回,否则就等待超时时间后返回
只能捕捉由spawn启动的进程的输出
用于接收命令执行后的输出,然后和期望的字符串匹配

  • 3.send

向进程发送字符串,用于模拟用户的输入
该命令不能自动回车换行,一般要加\r(回车)或\n

  • 4.结束符

expect eof (执行自动化任务通常使用expect eof)
等待执行结束
expect <<eof

eof

interact
执行完成后保持交互状态,把控制权交给控制台

  • 5.set

设置超时时间,过期则继续执行后续指令
单位是秒
timeout -l表示永不超时
默认情况下,timeout是10秒

  • 6.exp_continue

允许expect继续向下执行指令
解析:如果有一条语句错误,不加exp_continue,就会到此为止,退出
加上exp_continue会继续执行后续语句,不退出。

  • 7.send_user

回显命令,相当于echo

  • 8.接收参数

Expect脚本可以接受从bash传递的参数
可以使用[lindex $argv n]获得
n从0开始,分别表示第一个,第二个,第三个…参数
/bin/bash的位置变量是从$1开始到$9结束
Expect[lindex $argv 0]相当于/bin/bash的$1

多分支模式语法

  • 第一种:

expect “aaa” {send “AAA\r”}
expect “bbb” {send “BBB\r”}
expect “ccc” {send “CCC\r”}

send命令不具备回车换行功能,一般要加\r或\n

  • 第二种:

expect{
“aaa” {send “AAA\r”}
“bbb” {send “BBB\r”}
“ccc” {send “CCC\r”}
}

只要匹配了aaa或者bbb或者ccc中的任何一个,执行相应的send语句后退出该expect语句(只会匹配执行一条语句)

  • 第三种:

expect{
“aaa” {send “AAA”;exp_continue}
“bbb” {send “BBB”;exp_continue}
“ccc” {send “CCC”}
}

Expect项目

设置ssh登录免交互

[root@server2 ~]# vi expect.sh
#!/usr/bin/expect
# ssh免交互
set timeout 60                      设置超时时间60set hostname [lindex $argv 0]       设置变量名,变量值来自位置变量0
set password [lindex $argv 1]
log_file a.log                      设置日志文件记录保存的文件夹
log_user 1                          记录屏幕输出
spawn ssh root@$hostname            发起启动进程ssh某主机名
expect {
    "(yes/no)" {send "yes\r;exp_continue"}
    "password" {send "$password\r"}
}
interact
[root@server2 ~]# chmod +x expect.sh 
[root@server2 ~]# ./expect.sh 20.0.0.10 123456

在这里插入图片描述

嵌入执行

[root@server2 ~]# vi expect.sh
#!/bin/bash
# ssh免交互
hostname=$1
password=$2
/usr/bin/expect <<-EOF
spawn ssh root@$hostname
expect {
    "(yes/no)" {send "yes\r;exp_continue"}
    "password" {send "$password\r"}
}
expect "*]#" {send exit\r} 
expect eof     
EOF
[root@server2 ~]# chmod +x expect.sh 
[root@server2 ~]# ./expect.sh 20.0.0.10 123456

在这里插入图片描述

ssh生成密钥进行登录

[root@server2 ~]# vi sshmy.sh
#!/bin/bash
# ssh生成密钥的免交互
/usr/bin/expect <<-EOF
spawn ssh-keygen -t rsa
expect "(/root/.ssh/id_rsa)" {send "\r"}
expect "(empty for no passphrase)" {send "\r"}
expect "again" {send "\r"}
expect eof
EOF
[root@server2 ~]# chmod +x sshmy.sh 
[root@server2 ~]# ./sshmy.sh 

在这里插入图片描述

ssh免密登录

[root@server2 ~]# vi sshmy.sh
#!/bin/bash
# ssh生成密钥的免交互和免交互
hostname=$1
password=$2
/usr/bin/expect <<-EOF
spawn ssh-keygen -t rsa
expect "(/root/.ssh/id_rsa)" {send "\r"}
expect "(empty for no passphrase)" {send "\r"}
expect "again" {send "\r"}
expect eof
EOF
/usr/bin/expect <<-EOF
spawn ssh root@$hostname    //此处设置登录设备地址
expect "yes/no" {send "yes\r"}
expect "password" {send "$password\r"}  //此处输入登录设备秘密吗
expect "*]#" {send "exit\r"}
expect eof
EOF
[root@server2 ~]# chmod +x sshmy.sh 
[root@server2 ~]# ./sshmy.sh

在这里插入图片描述
在这里插入图片描述

利用expect完成FTP登录过程

配置ftpshell脚本文件

[root@server2 ~]# vi nmftp.sh
#!/bin/bash
# ftp安装和匿名用户登录
A=vsftpd
B=/etc/vsftpd/vsftpd.conf
yum -y install $A
sed -i -e '/local_enable/s/YES/NO/g' $B
sed -i -e '/listen/s/NO/YES/g' $B
sed -i -e '/listen_ipv6/s/YES/NO/g' $B
sed -i -e 's/^#anon_upload_enable=YES/anon_upload_enable=YES/g' $B
sed -i -e 's/^#anon_mkdir_write_enable=YES/anon_mkdir_write_enable=YES/g' $B
sed -i '$aanon_umask=022' $B
sed -i '$aanon_other_write_enable=YES' $B
systemctl start $A
netstat -anpt | grep $A
grep -v "#" $B | grep -v "^$"
[root@server2 ~]# chmod +x nmftp.sh 
[root@server2 ~]# ./nmftp.sh 

在这里插入图片描述

ftp登录

[root@client1 ~]# ftp 20.0.0.11

在这里插入图片描述

expect脚本,ftp一键登录

[root@client1 ~]# vi ftpdl.sh
#!/bin/bash
# ftp一键登录
hostname=$1
password=$2
/usr/bin/expect <<-EOF
spawn ftp $hostname
expect "Name" {send "ftp\r"}
expect "Password:" {send "$password\r"}
expect "ftp>" {send "ls -lh\r"}
interact
EOF
[root@client1 ~]# chmod +x ftpdl.sh 
[root@client1 ~]# ./ftpdl.sh 20.0.0.11 123456

在这里插入图片描述

磁盘初始化

[root@client1 ~]# vi cppz.sh
#!/bin/bash
# 初始化一块磁盘,格式化,挂载
 /usr/bin/expect<<-EOF
 spawn fdisk /dev/sdb
 expect {
     "命令(输入 m 获取帮助)" {send "n\r";exp_continue}
     "Select (default p)" {send "p\r";exp_continue}
     "分区号 (1-4,默认 1)" {send "1\r";exp_continue}
     "起始 扇区 (2048-41943039,默认为 2048)" {send "\r";exp_continue}
     "+size{K,M,G}" {send "\r"}}
     expect "命令(输入 m 获取帮助)" {send "p\r";send "wq\r";exp_continue}
EOF
fdisk -l
mkdir /data
mkfs.ext4 /dev/sdb1
mount /dev/sdb1  /data
df -Th
[root@client1 ~]# chmod +x cppz.sh 
[root@client1 ~]# ./cppz.sh 

在这里插入图片描述

还原初始状态

[root@client1 ~]# umount /data/
[root@client1 ~]# rm -rf /data/
[root@client1 ~]# fdisk /dev/sdb

在这里插入图片描述

方法二

[root@client1 ~]# vi cpgs.sh
#!/bin/bash
a=`ls /dev/sd* | grep -o sd[b-z] | uniq`
for var in $a
do
   echo -e "n\np\n\n\n\nwq\n" | fdisk /dev/$var   支持转义字符
   mkfs.ext4 /dev/${var}"1"                             重分发
   mkdir -p /data/${var}"1"                             创建
   mount /dev/${var}"1" /data/${var}"1"                 挂载
done
[root@client1 ~]# chmod +x cpgs.sh 
[root@client1 ~]# ./cpgs.sh 

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值