背景:
在使用crontab管理定时脚本时,若是设定的脚本执行时间间隔较短,例如5分钟执行一次,正常状况下,脚本执行耗时1分钟,在非正常状况下(如服务器压力较大的状况下,或数据量忽然增大),脚本执行时间超过5分钟,这时就会形成多个脚本同时执行,严重时甚至拖垮服务器,影响服务器上的其它服务mysql
举个例子,每10分钟更新mysql数据的脚本sql
5/* * * * * sh /services/scripts/update_mysql_data.sh
一般状况下,脚本执行只须要30s,可是某天忽然有人修改数据结构,形成锁表,脚本一直等待执行。超过5分钟的间隔够,脚本又会执行一次,最后等发现问题时,已是业务方收到影响了shell
这时就须要Linux的文件锁-flock!segmentfault
flock简介:
当多个进程可能会执行同一个脚本,这些进程须要保证其它进程没有在操做,以避免重复执行。一般,这样的进程会使用一个「锁文件」,也就是创建一个文件来告诉别的进程本身在运行,若是检测到那个文件存在则认为有操做一样数据的进程在工做。bash
使用方法:服务器
flock -h Usage: flock [options] <file|directory> <command> [command args] flock [options] <file|directory> -c <command> flock [options] <file descriptor number> Options: -s, --shared: 得到一个共享锁 -x, --exclusive: 得到一个独占锁 -u, --unlock: 移除一个锁,一般是不须要的,脚本执行完会自动丢弃锁 -n, --nonblock: 若是没有当即得到锁,直接失败而不是等待 -w, --timeout: 若是没有当即得到锁,等待指定时间 -o, --close: 在运行命令前关闭文件的描述符号。用于若是命令产生子进程时会不受锁的管控 -c, --command: 在shell中运行一个单独的命令 -h, --help 显示帮助 -V, --version: 显示版本
了解flock了,咱们就能够对上面的脚本进行改进数据结构
5/* * * * * flock -xn /services/scripts/update_mysql_data.lock -c 'sh /services/scripts/update_mysql_data.sh'
当/services/scripts/update_mysql_data.lock
被进程占用时,别的进程就不会再重复执行文件。还有一个好处是,不须要手动释放锁,禁止执行完以后会自动释放对lock文件的占用学习