Linux篇:shell中while read line的用法及实战

01 前言

在shell脚本中,我们经常看到以下的一种结构:

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 while read line 与for 循环的区别

看完上面的定义,可能很多同学会说这是不是和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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容