欢迎各位兄弟 发布技术文章
这里的技术是共享的
pid file是一个文件,里面保存了后台程序的pid。
其他程序可以通过这个pid文件,获取这个后台程序的pid,然后执行一些任务。
当别的用户启动这个后台程序的时候,可以检查这个文件,防止出现多个相同后台程序。
使用pid file,需要几个步骤:
找个目录创建这个pid文件,在linux系统中,一般放在/var/run/program.pid, program是运行的程序名。
获取进程pid,并且写入上面的文件中。
读取文件中的pid,给其他程序或者自身程序使用。
通过几种方法判定读取的pid存在
向这个pid发送0信号kill(0, pid),存在返回成功,失败返回失败
func killMethod(pid int) error {
return syscall.Kill(pid, 0)
}
检查/proc/pid的状态,pid存在检查成功,pid不存在返回失败
func procMethod(pid int) error {
_, err := os.Stat(filepath.Join("/proc", strconv.Itoa(pid)))
return err
}
创建时为该文件加锁,当pid存在时,对该文件的创建修改操作都会失败。
参考:https://github.com/moby/moby/...
来自 https://segmentfault.com/a/1190000019036070
先给大家介绍下Linux下/var/run/目录下的pid文件,具体详解如下所示:
linux系统中/var/run/目录下的*.pid文件是一个文本文件,其内容只有一行,即某个进程的PID。.pid文件的作用是防止进程启动多个副本,只有获得特定pid文件(固定路径和文件名)的写入权限(F_WRLCK)的进程才能正常启动并将自身的进程PID写入该文件,其它同一程序的多余进程则自动退出。
编程实现:
调用fcntl()系统调用设置指定的pid文件为F_WRLCK锁状态,如果锁成功则写入当前进程的PID,进程继续往下执行;如果上锁失败则说明已经有同样的进程在运行了,当前进程退出。
需要注意:
1.程退出后该进程加的锁自动失效;
2.进程关闭了该文件描述符fd,则加的锁失效。(所以整个进程生命周期内不能关闭该fd);
3.锁的状态不会被子进程继承,如果进程关闭则失效而不管子进程是否运行。
下面介绍下Linux下/var/run目录下的pid文件作用
在Linux系统的目录/var/run下面一般我们都会看到很多的*.pid文件。而且往往新安装的程序在运行后也会在/var/run目录下面产生自己的pid文件。那么这些pid文件有什么作用呢?它的内容又是什么呢?
(1) pid文件的内容:pid文件为文本文件,内容只有一行, 记录了该进程的ID。
用cat命令可以看到。
(2) pid文件的作用:防止进程启动多个副本。只有获得pid文件(固定路径固定文件名)写入权限(F_WRLCK)的进程才能正常启动并把自身的PID写入该文件中。其它同一个程序的多余进程则自动退出。
(3) 编程技巧:
调用fcntl设置pid文件的锁定F_SETLK状态,其中锁定的标志位F_WRLCK。
如果成功锁定,则写入进程当前PID,进程继续往下执行。
如果锁定不成功,说明已经有同样的进程在运行了,当前进程结束退出。
(4) 一些注意事项:
i) 如果进程退出,则该进程加的锁自动失效。
ii) 如果进程关闭了该文件描述符fd, 则加的锁失效。(整个进程运行期间不能关闭此文件描述符)
iii) 锁的状态不会被子进程继承。如果进程关闭则锁失效而不管子进程是否在运行。
总结
以上所述是小编给大家介绍的Linux下/var/run/目录下的pid文件详解及pid文件作用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
来自 https://www.jb51.net/article/137999.htm