通过脚本案例学习shell(一)
--- 如何通过复杂锁脚本得知脚本正在运行或者被意外中断
锁是一种机制,是程序与程序之间协同工作的一种机制。
运行脚本程序会遇到以下问题:
1、早上你打开电脑运行了一个时间比较长的脚本,突然被老板叫了过去,等你回来你缺忘了是否运行过此脚本怎么办?
2、有一天你正在运行某一个脚本,服务器突然宕机,但是你又想知道脚本是否运行完成.
如何解决以上问题呢!
有一种方法是通过在脚本运行之前创建一个锁文件,通过判断锁文件是否存在而判断脚本是否在执行.
下面通过一个复杂锁实现脚本的自动化运维过程.
如果思路如下:
运行脚本前,判断锁文件是否存在,如果存在,说明此脚本可能正在运行也有可能是脚本被意外中断,然后通过判断运行的脚本PID和之前运行的PID是否一致,如果一致,说明脚本正在运行,如果不一致说明脚本是被意外中断,会重新运行此脚本。
- #!/bin/bash
- LOCKFILE=/tmp/$(basename $0)_lockfile //设置变量
- if [ -f $LOCKFILE ];then //假如锁文件存在
- MYPID=$(cat $LOCKFILE) //查看锁文件中的PID值
- ps -p $MYPID | grep $MYPID &>/dev/null //比较PID是否一致
- [ $? -eq 0 ] && echo "The script backup.sh is running" && exit 1 //PID一致,则显示运行信息,并退出脚本
- else
- echo $$ > $LOCKFILE //如果锁文件不存在或者锁文件存在,PID不一样,则将新的PID值写入锁文件
- fi
- bash /etc/backup.sh //写你要运行的脚本
- rm -rf $LOCKFILE //成功之后删除锁文件
部分脚本分析
bash /etc/backup.sh ($0=/etc/backup.sh)
basename $0 显示路径后面的文件名backup.sh
$? 判断上一个语句执行是否有显示正确结果,如果正确显示为0,如果不正确显示非0数字。
$$ 显示父进程ID
通过read命令设置断点进行简单测试锁文件脚本是否OK
- #!/bin/bash
- LOCKFILE=/tmp/$(basename $0)_lockfile
- if [ -f $LOCKFILE ];then
- MYPID=$(cat $LOCKFILE)
- ps -p $MYPID | grep $MYPID &>/dev/null
- [ $? -eq 0 ] && echo "The script backup.sh is running" && exit 1
- else
- echo $$ > $LOCKFILE
- fi
- echo "The script is running!"
- read
- echo "The script is stop!"
- rm -rf $LOCKFILE
测试1、脚本正常运行结束效果。
read是个断点命令,脚本会一致停留着那里,直到按回车进入吓一跳命令
测试2、脚本正在运行测试效果
打开一个终端运行锁脚本
打开另一个终端再次运行锁脚本,由于脚本正在运行,所以在此打开的脚本不会被运行。
测试2、脚本意外中断测试效果
通过Ctrl+c 模拟脚本中断,由于两次的PID不一致,所以脚本会被重新运行。
本文转自凌激冰51CTO博客,原文链接:http://blog.51cto.com/dreamfire/1152067,如需转载请自行联系原作者