美文网首页jouypub.com
Linux文件锁-flock

Linux文件锁-flock

作者: JouyPub | 来源:发表于2019-05-22 10:12 被阅读0次

背景:
在使用crontab管理定时脚本时,如果设定的脚本执行时间间隔较短,例如5分钟执行一次,正常情况下,脚本执行耗时1分钟,在非正常情况下(如服务器压力较大的情况下,或数据量突然增大),脚本执行时间超过5分钟,这时就会造成多个脚本同时执行,严重时甚至拖垮服务器,影响服务器上的其它服务

举个例子,每10分钟更新mysql数据的脚本

5/* * * * * sh /services/scripts/update_mysql_data.sh

通常情况下,脚本执行只需要30s,但是某天突然有人修改数据结构,造成锁表,脚本一直等待执行。超过5分钟的间隔够,脚本又会执行一次,最后等发现问题时,已经是业务方收到影响了

这时就需要Linux的文件锁-flock!

flock简介:
当多个进程可能会执行同一个脚本,这些进程需要保证其它进程没有在操作,以免重复执行。通常,这样的进程会使用一个「锁文件」,也就是建立一个文件来告诉别的进程自己在运行,如果检测到那个文件存在则认为有操作同样数据的进程在工作。

使用方法:

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文件的占用

欢迎订阅「K叔区块链」 - 专注于区块链技术学习
博客地址:http://www.jouypub.com
简书主页:https://www.jianshu.com/u/756c9c8ae984
segmentfault主页:https://segmentfault.com/blog/jouypub
腾讯云主页:https://cloud.tencent.com/developer/column/72548

相关文章

  • Linux文件锁-flock

    背景:在使用crontab管理定时脚本时,如果设定的脚本执行时间间隔较短,例如5分钟执行一次,正常情况下,脚本执行...

  • Linux的文件锁flock

    今天看腾讯云服务器的脚本时,发现在root用户的crontab定时任务里面有个函数flock。在每五分钟执行脚...

  • linux c文件锁flock

    1.源码实现 2.编译源码 3.运行及其结果

  • 了解cephfs锁必须要知道的事情

    1、本文讨论的锁不是flock。flock是posix标准中对文件某部分偏移加的锁。而这里的锁指的是MDS集中管理...

  • linux使用flock文件锁解决脚本重复执行问题

    关于forck flock 是对于整个文件的建议性锁。也就是说,如果一个进程在一个文件(inode)上放了锁,那么...

  • 12.3.5 文件的锁定机制

    12.3.5 文件的锁定机制 flock -- 轻便的咨询文件锁定语法: bool flock ( int han...

  • 使用文件锁flock实现进程互斥

    最近写了一个python脚本,对Android设备进行自动化测试。当重复执行脚本时,如果不对访问设备进行锁控制,不...

  • Linux 文件锁

    系统调用fcntl 参数:fd:文件描述符cmd:F_GETLK, F_SETLK or F_SETLKWlock...

  • flock v.s. fcntl

    共同点 都支持阻塞和非阻塞模式 只能操作于文件,而不是目录 当进程结束或者终止的时候,锁都会被自动释放 flock...

  • 2018-11-11网络攻防第五周学习文档

    Linux 了解了linux的文件系统一些基本概念,如链接,互斥锁,共享锁等,还有有关文件系统的系统调用,crea...

网友评论

    本文标题:Linux文件锁-flock

    本文链接:https://www.haomeiwen.com/subject/gbcyzqtx.html