Linux Shell编程及自动化运维实现 循环

Shell循环:for
语法结构
for 变量名 [ in 取值列表 ]
do
循环体
done
示例
需求
自动循环创建10个用户
示范
for i in {1…10}
do
useradd “user$i”
done
for i in $(seq 1 10)
也可以哦
for i in seq 10
对比C语言
C语言:
for ((初值;条件;步长))
do
循环体
done
案例1: ping测试主机
案例1: 通过循环工具,探测全网主机。将在线主机记录在文本中。
[root@tianyun scripts]# cat ip.txt
172.16.8.100
172.16.8.4
172.16.100.254

		演示
			1 编写常规ping测试脚本(无循环)
			2 添加循环语句。for i in {2..254}
			3 优化脚本(后台执行,清空脚本,循环完成提示,wait间隔)
			4 示例
				1 编写常规网络测试脚本

#!/bin/bash
#ping
ip=192.168.100.10
ping -c1 -W1 $ip &> /dev/null
if [ ? − e q 0 ] ; t h e n e c h o " ? -eq 0 ] ;then echo " ?eq0];thenecho"ip" |tee -a ip.txt
fi

2 因为测试对象多,所以使用循环。
#!/bin/bash
#ping

for i in {2…254}
do

ip=192.168.100.$i
ping -c1 -W1 $ip &> /dev/null
if [ ? − e q 0 ] ; t h e n e c h o " ? -eq 0 ] ;then echo " ?eq0];thenecho"ip" |tee -a ip.txt
fi

done

3 优化脚本(后台执行,清空脚本,wait间隔)

#!/bin/bash
#ping

ip.txt ##清空记录文本

for i in {2…254}
do
{
ip=192.168.100.$i
ping -c1 -W1 $ip &> /dev/null
if [ ? − e q 0 ] ; t h e n e c h o " ? -eq 0 ] ;then echo " ?eq0];thenecho"ip" |tee -a ip.txt
fi
}& ##后台执行
done
wait ##等待前一个程序执行完毕。在执行下一个命令。
echo “finishi…”
案例2: 通过用户列表文件创建用户
案例1: 通过用户列表文件创建用户
[root@tianyun scripts]# cat user.txt
qianqian
qianfeng
fengfeng
示例
#!/bin/bash
for user in cat user.txt
do
useradd u s e r e c h o " user echo " userecho"user is created"
done
升级1
用户可以使用参数的形式,自定义用户名文件。
如果用户没有输入用户名文件,提示用户输入
如果用户输入的不是文件,提示用户更正。
启动循环创建用户
如果用户已经存在,提示存在
如果用户不存在,则创建成功,提示成功

#!/bin/bash
#name
#time
pass=123
#判断脚本是否有参数
if [ $# -eq 0 ] ;then
echo “usage:$0 filename "
exit 1
fi
#判断用户输入的是否是文件
if [ ! -f $1 ];then
echo “error filename”
exit 2
fi
#设置循环,读取文件,创建用户
for user in cat $1
do
id $user &> /dev/null
#如果用户不存在,则创建用户,否则提示已经存在。
if [ $? -eq 0 ];then
echo “user $user already exists”
else
useradd u s e r e c h o " user echo " userecho"pass” | passwd --stdin $user &> /dev/null
#判断用户是否创建成功,并提示
if [ ? − e q 0 ] ; t h e n e c h o " ? -eq 0 ] ; then echo " ?eq0];thenecho"user is created."
fi
fi
done

案例3:使用for实现批量主机root密码的修改
	前提1:已经完成秘钥登录配置(ssh-keygen)

前提2:定义主机地址列表
前提3:并了解远程修改密码的方法
步骤
1 邀请用户输入密码
2 循环调用IP地址
3 执行远程修改(ssh 192.168.122.20 “touch ~/ddd.txt”)
4 记录执行结果

				免密码登录
					ssh-keygen
					ssh-copy-ip ip地址
			
		优化
			 美化脚本(后台执行,隐藏密码输入,判断密码是否一致,)
			while :

do
read -s -p "请输入一个新密码: " pass1
echo “”
read -s -p "请再次输入您的新密码: " pass2
if [ ! $pass1 == $pass2 ] ;then
echo “”
echo “新密码不一致,请重新输入。”
else
break
fi
done
echo “”
echo “恭喜你!终于输入成功!”

Shell循环:while until
特点
循环次数不[一定]是固定的
一、while语句结构
一、while语句结构(死循环/逐行处理文件)
while 条件测试
do
循环体
done
==当条件测试成立(条件测试为真),执行循环体
示例1
每秒显示一个数字,一次递增+1
while :
do
let i++
sleep 1
echo $i
done
二、until语法结构
二、until语法结构
until 条件测试
do
循环体
done
==当条件测试成立(条件测试为假视为成立),执行循环体
示例1
需求:每个一秒循环一个数字
演示
#!/bin/bash
until [[ $i -eq 14 ]]
do
let i++
sleep 1
echo $i
done

		示例2
			需求
				每隔5秒查看aofa用户是否登录,循环往复。

如果该用户登录,请显示登录并退出监控程序;
否则显示当前时间,并输出aofa尚未登录
示范
#!/bin/bash
until who | grep “^aofa” &> /dev/null
do
echo “$(date) aofa not login”
sleep 5
done
echo “aofa login”
exit 0
三循环总结
固定 :for
逐行:while
逐行/不固定:while until
expect
前言
观察ssh登录的交互现象
有些程序难以避免的需要交互。你该如何解决脚本与程序的交互问题?
名词解释
期待, 预期, 盼望, 预料,料想, 指望, 希望, 要求,想, 认为
一、概述

我们通过Shell可以实现简单的控制流功能,如:循环、判断等。但是对于需要交互的场合则必须通过人工来干预,有时候我们可能会需要实现和交互程序如telnet服务器等进行交互的功能。而Expect就使用来实现这种功能的工具。

Expect是一个免费的编程工具语言,用来实现自动和交互式任务进行通信,而无需人的干预。Expect的作者Don Libes在1990年开始编写Expect时对Expect做有如下定义:Expect是一个用来实现自动交互功能的软件套件 (Expect [is a] software suite for automating interactive tools)。使用它系统管理员 的可以创建脚本用来实现对命令或程序提供输入,而这些命令和程序是期望从终端(terminal)得到输入,一般来说这些输入都需要手工输入进行的。 Expect则可以根据程序的提示模拟标准输入提供给程序需要的输入来实现交互程序执行。甚至可以实现实现简单的BBS聊天机器人。😃

Expect是不断发展的,随着时间的流逝,其功能越来越强大,已经成为系统管理员的的一个强大助手。Expect需要Tcl编程语言的支持,要在系统上运行Expect必须首先安装Tcl。

二、Expect工作原理

从最简单的层次来说,Expect的工作方式象一个通用化脚本工具。用来实现计算机之间需要建立连接时进行特定的登录会话的自动化。

脚本由一系列expect-send对组成:expect等待输出中输出特定的字符,通常是一个提示符,然后发送特定的响应。
解决人机交互的问题
安装
yum install -y expect tcl tclx tcl-devel
示例1:
通过expect解决ssh交互问题
1 通过expect编写脚本
示例
#!/usr/bin/expect
spawn ssh root@192.168.0.111

expect {
“yes/no” { send “yes\r”;exp_continue }
“password:” { send “666666\r” };
}
interact

		2 登录验证免交互
			解释
				spawn  expect 内部命令,启动一个shell程序。
				expect 期望哪些内容
				yes/no  就send发送 yes ,\r  表示回车 
				password 就send发送 centos
				exp_continue,跳过循环,就继续下一条语句。
				interact 允许用户交互
示例2:
	expect实战:公钥推送
		准备工作:安装expect,准备公钥
		1 通过shell循环判断在线主机
			#!/bin/bash

#创建一个IP地址文件。

ip.txt
#使用for循环ping测试主机是否在线。
for i in {2…254}
do
{
#学员请注意练习环境的IP地址,可能与示例中不同。
ip=192.168.0.$i
ping -c1 -W1 $ip &> /dev/null
if [ ? − e q 0 ] ; t h e n e c h o " ? -eq 0 ];then echo " ?eq0];thenecho"ip" >> ip.txt
fi
}&
done

			vim ip.txt 观察在线主机
		2 通过expect进行交互
			#!/bin/bash

#创建一个IP地址文件。

ip.txt
#使用for循环ping测试主机是否在线。
for i in {2…254}
do
{
#学员请注意练习环境的IP地址,可能与示例中不同。
ip=192.168.122.$i
ping -c1 -W1 $ip &> /dev/null
if [ ? − e q 0 ] ; t h e n e c h o " ? -eq 0 ];then echo " ?eq0];thenecho"ip" >> ip.txt

    /usr/bin/expect <<-EOF

set timeout 10
spawn ssh-copy-id $ip
expect {
“yes/no” { send “yes\r”; exp_continue }
“password:” { send “centos\r” }
}
expect eof
EOF
fi
}&
done
wait
echo “finishi…”

				#!/usr/bin/expect

set timeout 10
spawn ssh-copy-id 192.168.122.152
expect {
“yes/no” { send “yes\r”; exp_continue }
“password:” { send “centos\r” }
}

		3 优化脚本
			安装和公钥
			示例
				#!/bin/bash

#创建一个IP地址文件。

ip.txt
#检测expect是否安装,检测公钥是否创建。
rpm -q expect &> /dev/null
if [ $? -ne 0 ] ;then
yum install -y expect
fi
if [ ! -f ~/.ssh/id_rsa ];then
ssh-keygen -P “” -f ~/.ssh/id_rsa
fi
#使用for循环ping测试主机是否在线。之前插入安装和准备秘钥。

		学员虚拟机环境重置
学员练习。体验expect的免交互
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值