zoukankan      html  css  js  c++  java
  • 进程锁

    这里的进程锁与线程锁、互斥量、读写锁和自旋锁不同,它是通过记录一个PID文件,避免两个进程同时运行的文件锁。
    进程锁的作用之一就是可以协调进程的运行,例如crontab使用进程锁解决冲突提到,使用crontab限定每一分钟执行一个任
    务,但这个进程运行时间可能超过一分钟,如果不用进程锁解决冲突的话两个进程一起执行就会有问题。后面提到的项目实
    例Run也有类似的问题,通过进程锁可以解决进程间同步的问题。
    使用PID文件锁还有一个好处,方便进程向自己发停止或者重启信号。Nginx编译时可指定参数 --pid-
    path=/var/run/nginx.pid  ,进程起来后就会把当前的PID写入这个文件,当然如果这个文件已经存在了,也就是前一个进程还
    没有退出,那么Nginx就不会重新启动。进程管理工具Supervisord也是通过记录进程的PID来停止或者拉起它监控的进程的。
    进程锁在特定场景是非常适用的,而操作系统默认不会为每个程序创建进程锁,那我们该如何使用呢?
    其实要实现一个进程锁很简单,通过文件就可以实现了。例如程序开始运行时去检查一个PID文件,如果文件存在就直接退
    出,如果文件不存在就创建一个,并把当前进程的PID写入文件中。这样我们很容易可以实和读锁,但是所有流程都需要自
    己控制。
    当然根据DRY(Don't Repeat Yourself)原则,Linux已经为我们提供了 flock  接口。

  • 相关阅读:
    mac 终端常见指令
    git常见指令
    iOS8的autolayout和size class
    UIWindow详解
    操作系统Unix、Windows、Mac OS、Linux的故事
    iOS引用当前显示的UIAlertView
    Unexpected CFBundleExecutable Key
    《CODE》讲了什么?
    exit和return的区别
    php 登录注册api接口代码
  • 原文地址:https://www.cnblogs.com/zendu/p/4981207.html
Copyright © 2011-2022 走看看