大佬教程收集整理的这篇文章主要介绍了Python守护程序和systemd服务,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
原因是,它没有完成启动顺序,是因为对于Type,forking
您的启动过程需要分叉并退出(请参阅$ man systemd.service-搜索分叉)。
只需使用主过程,不守护 一种选择是减少工作量。使用systemd时,通常无需创建守护程序,您可以直接运行代码而不进行守护程序。
#!/usr/bin/python -u
from somewhere import Node
check = Node()
check.run()
这允许使用称为的更简单的服务类型simple,因此您的单位文件将看起来像。
[Unit]
Description=SimplifIEd simple zebra service
After=syslog.target
[service]
Type=simple
User=node
Group=node
WorkingDirectory=/home/node/Node/
ExecStart=/home/node/Node/node.py
StandardOutput=syslog
StandardError=syslog
[Install]
WantedBy=multi-user.target
请注意,-u
不需要使用in python shebang,但是如果您将某些内容输出到stdout或stderr,请-u确保没有适当的输出缓冲,并且系统会立即捕获打印的行并将其记录在日志中。没有它,它会出现一些延迟。
为此,我将行StandardOutput=syslog
和添加到了单元文件中StandardError=syslog
。如果您不关心日记本中的打印输出,则不必关心这些行(不必存在)。
虽然您的问题的标题明确询问了有关守护程序的问题,但我想,问题的核心是“如何使我的服务运行”,而使用主进程似乎要简单得多(您根本不必关心守护程序),可以被视为您问题的答案。
我认为,许多人之所以使用守护进程,只是因为“每个人都这样做”。使用systemd时,守护进程的原因通常已过时。使用守护程序可能有一些原因,但是现在很少见。
编辑:固定python -p
为正确python -u
。
我有一个简单的Python脚本充当守护程序。我试图创建systemd脚本,以便能够在启动过程中启动此脚本。
当前的systemd脚本:
[Unit]
Description=Text
After=syslog.target
[service]
Type=forking
User=node
Group=node
WorkingDirectory=/home/node/Node/
PIDFile=/var/run/zebra.pid
ExecStart=/home/node/Node/node.py
[Install]
WantedBy=multi-user.target
node.py:
if __name__ == '__main__':
with daemon.DaemonContext():
check = Node()
check.run()
run
包含while True
循环。
我尝试使用运行该服务systemctl start zebra-node.service
。不幸的是,服务从未完成说明序列-我必须按Ctrl + C。脚本正在运行,但是状态为激活,一段时间后变为停用状态。现在我正在使用python-daemon
(但是在我尝试不使用它之前,症状是相似的)。
我应该为脚本实现一些其他功能还是systemd文件不正确?
以上是大佬教程为你收集整理的Python守护程序和systemd服务全部内容,希望文章能够帮你解决Python守护程序和systemd服务所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。