Linux篇:shell中whilereadline的⽤法及实战
01 前⾔
在shell脚本中,我们经常看到以下的⼀种结构:
linux循环执行命令脚本while read line
do
…
done < file
可能不熟悉shell的⼈看到这个会有点懵,其实这是shell中while read line的⼀种⽤法:
read通过输⼊重定向,把file的第⼀⾏所有的内容赋值给变量line,循环体内的命令⼀般包含对变量line的处理;然后循环处理file的第⼆⾏、第三⾏。。。⼀直到file的最后⼀⾏。
还记得while根据其后的命令退出状态来判断是否执⾏循环体吗?
是的,read命令也有退出状态,当它从⽂件file中读到内容时,退出状态为0,循环继续进⾏;
当read从⽂件中读完最后⼀⾏后,下次便没有内容可读了,此时read的退出状态为⾮0,所以循环才会退出。
02 w hile r ea d line 与fo r 循环的区别
看完上⾯的定义,可能很多同学会说这是不是和for循环⼀样,这我们作⼀下说明:
while read line 是⼀次性将⽂件信息读⼊并按⾏赋值给变量line ,while中使⽤重定向机制,⽂件中的所有信息都被读⼊并重定向给了整个while 语句中的line 变量。
for是每次读取⽂件中⼀个以空格为分割符的字符串。
03 实战
题⽬:利⽤while read line 实现MySQL的分库备份,备份频次为每天,要求备份数据存储在每⼀个以数据库名的⽂件夹中
第⼀步:获取需备份的数据库名
# 使⽤mysql命令⾏获取数据库名,存储到mysql.name⽂件中
mysql -uroot -proot -e "show databases" | sed 1,2d >mysql.name
第⼆步:建⽴while read line 结构
while read line
do
...
done < mysql.name
第三步:定义时间戳变量及备份路径输出记录⽇志
time1=` date +%Y%m%d`
time2= ` date +%Y-%m-%d%t%H:%M:%S `
mysql -uroot -proot -e "show databases" | sed 1,2d >mysql.name
while read line
do
dir=/data/mysql/${line}/
log=/data/mysql/${line}/${line}-${time1}.out
[ -d $dir ] && echo " ">/dev/null 2>&1 || mkdir -p $dir
[ -f $log ] && echo " ">/dev/null 2>&1 || touch $log
done < mysql.name
第四步:while循环中加⼊备份命令
time1=` date +%Y%m%d `
time2= ` date +%Y-%m-%d%t%H:%M:%S `
mysql -uroot -proot -e "show databases" | sed 1,2d >mysql.name
while read line
do
dir=/data/mysql/${line}/
log=/data/mysql/${line}/${line}-${time1}.out
[ -d $dir ] && echo " ">/dev/null 2>&1 || mkdir -p $dir
[ -f $log ] && echo " ">/dev/null 2>&1 || touch $log
mysqldump -uroot -proot -B ${line} > ${dir}/${line}-${time1}.sql
done < mysql.name
第五步:完善⽇志记录部分及脚本安全部分,完整脚本如下
set -u
set -e
time1=` date +%Y%m%d`
time2= ` date +%Y-%m-%d%t%H:%M:%S `
mysql -uroot -proot -e "show databases" | sed 1,2d >mysql.name while read line
do
dir=/data/mysql/${line}/
log=/data/mysql/${line}/${line}-${time1}.out
[ -d $dir ] && echo " ">/dev/null 2>&1 || mkdir -p $dir
[ -f $log ] && echo " ">/dev/null 2>&1 || touch $log
echo ${time1}>>${log}
mysqldump -uroot -proot -B ${line} > ${dir}/${line}-${time1}.sql if [ S? -eq 0 ];then
echo "【${time2}】,数据库名:${line},备份成功!">>${log} else
echo "【${time2}】,数据库名:${line},备份失败!">>${log} fi
done < mysql.name
第六步:加⼊定时任务
00 03 * * * sh /home/gzcb/shell/mysql_backup.sh
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论