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小时内删除。