系统相关
首页 > 系统相关> > Python的守护进程PPID不等于1

Python的守护进程PPID不等于1

作者:互联网

Linux中创建守护进程是quite complex问题,但它在daemon(7) manual中有很好的文档.值得庆幸的是,有用于Python 2的python-daemon模块和用于实现PEP3143的3,所以我正在使用它.

问题出在这里:当我玩python-daemon模块时,我很惊讶守护进程的PPID不是1.为什么?

简单的例子:

import daemon
import time
import os

with open('/tmp/test.log', 'w') as logfile:
    c = daemon.DaemonContext(stdout=logfile)
    with c:
        print('In daemon...')
        for i in range(10):
            print('My PID is {}, PPID is {}'.format(os.getpid(), os.getppid()))
            time.sleep(2)

启动上述脚本20秒后test.log的内容(建议tail -f /tmp/test.log):

In daemon...
My PID is 31397, PPID is 1736
My PID is 31397, PPID is 1736
My PID is 31397, PPID is 1736
My PID is 31397, PPID is 1736
My PID is 31397, PPID is 1736
My PID is 31397, PPID is 1736
My PID is 31397, PPID is 1736
My PID is 31397, PPID is 1736
My PID is 31397, PPID is 1736
My PID is 31397, PPID is 1736

原来,PID 1736的过程是/lib/systemd/systemd

patryk@mycomp:/tmp$ps -fq 1736
UID        PID  PPID  C STIME TTY          TIME CMD
patryk    1736     1  0 kwi12 ?        00:00:00 /lib/systemd/systemd --user

最近我在C(在安装了systemd的同一台机器上)实现守护进程,而AFAIR所有守护进程都有PPID = 1.我遇到的所有手册都提到守护进程的PPID始终是1.

systemd改变了吗? systemd是否为所有进程处理awaits – 包括守护进程?是守护进程的正确行为吗?

相关问题:

> How do you create a daemon in Python?
> How do I set up a daemon with python-daemon?
> How to make a Python script run like a service or daemon in Linux
> Python 3.3.4: python-daemon-3K ; How to use runner

解决方法:

简短的回答是:没关系.

重要的是,所有守护进程都有一个像init这样的父进程,通过调用wait()会在子进程死亡时收获它们.否则,该过程将在退出时变为僵尸.

将父PID设置为1并没有什么特别之处.您链接到的手册页说明这个过程对于旧的SysV风格的守护进程是PID 1,但对于新的SystemD风格的守护进程则没有这样说. init始终作为PID 1运行,而传统上它是守护进程的父级.但它不需要如此.

systemd --user管理用户服务.因此,当您运行它(作为用户)时,为什么这个进程成为您的守护进程的父进程是有道理的.

在阅读关于* nix的文档时必须要小心,这个平台已经存在了几十年.事情发生变化,手册变得过时,或者可能在错误的环境中被解释. SystemD为Linux平台带来了很多重大变化.

标签:python,linux,pid,systemd,python-daemon
来源: https://codeday.me/bug/20190627/1307647.html