linux进程序列化,如何在linux上序列化命令执行?

我想确保系统中的任何常规用户一次只能运行一个脚本.可以有多个用户登录,并且每个用户只能在其他用户的任何运行命令完成后才能运行命令.

很久以前在UNIX上,我使用批处理命令和一个适当的“仅一个任务”队列定义来序列化脚本执行.它解决了许多锁管理问题(它只需要在脚本中设置一个简单的超时).

现在在Linux上,批处理命令的执行方式不同,每分钟运行一个任务,并行运行任务,直到达到1.5个负载平均值.

我创建了自己的锁管理shell库来序列化执行,但我想知道是否有一个标准命令来执行此操作.

解决方法:

羊群非常适合这个.您可以在shell脚本的包装器中使用flock,在命令行中使用它,或将其合并到脚本本身中.

关于flock的最好的事情是,当它等待时,它不会在繁忙的循环中等待.

当您的进程退出/ flock退出时,它也会始终清除锁定.

如果进程退出而没有清理(或者如果存在内核崩溃或电源故障,……),则基于原子文件/目录创建的方法可能会被锁定.

使用flock,Linux内核可以进行清理.

从手册,

(

flock -s 200

# ... commands executed under lock ...

) 200>/var/lock/mylockfile

在此表单中,您可以在shell脚本中包装特定的代码块.

或者你可以像这样运行它,

/usr/bin/flock /tmp/lockfile command

如果您不想无限期地阻止/等待,可以指定超时:

-w --timeout wait for a limited amount of time

或者只使用非阻塞参数:

-n --nonblock fail rather than wait

标签:linux,background-process

来源: https://codeday.me/bug/20190810/1638024.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值