- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我有一个作为守护进程工作的简单 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 文件不正确?
最佳答案
它没有完成启动序列的原因是,对于类型 forking
,您的启动过程预计会 fork 并退出(请参阅 $ man systemd.service - search for forking)。
一种选择是少做。使用 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
请注意,python shebang 中的 -u
不是必需的,但是如果您将某些内容打印到 stdout 或 stderr,则 -u
确保存在没有适当的输出缓冲,打印的行将立即被 systemd 捕获并记录在日志中。没有它,它会出现一些延迟。
为此,我在单元文件中添加了 StandardOutput=syslog
和 StandardError=syslog
行。如果您不关心日记中的打印输出,请不要关心这些行(它们不必存在)。
systemd
使守护进程过时虽然您的问题的标题明确询问了守护进程,但我猜,问题的核心是“如何让我的服务运行”,而 使用主进程似乎要简单得多(您不需要必须关心守护进程),它可以被视为您问题的答案。
我认为,很多人使用守护进程只是因为“每个人都这样做”。使用 systemd 守护进程的原因通常是过时的。使用守护进程可能有一些原因,但现在很少见。
编辑:将 python -p
固定为正确的 python -u
。谢谢kmftzg
关于Python 守护进程和 systemd 服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13069634/
一 点睛 线程可以设置为守护线程,ThreadGroup 也可以设置为守护 ThreadGroup,但是若将一个 ThreadGroup 设置为 deamon,也并不会影响线程的 daemon 属性,
我有一个 python 脚本需要在启动时作为守护进程运行。进程从 tty(和 pdb)分离,但代码不运行。 我已经将它缩小到一个最小的例子 import daemon from time import
reactjs isMounted API 的文档提到: You can use this method to guard asynchronous calls to setState() or fo
我正在开发一个需要嵌入 HTTP 服务器的守护进程。我正在尝试使用 BaseHTTPServer 来完成它,当我在前台运行它时,它工作正常,但是当我尝试将守护进程 fork 到后台时,它停止工作。我的
我正在尝试使用 Apache Commons Daemon 使用 Daemon 接口(interface)来守护我的应用程序。 Java 应用程序本身不执行任何操作,只是写入 stout。 我编译了j
我正在使用 Bootle Python Web Framework 在 Ubuntu 上开发网络应用程序。是否有任何有效的方法来守护启动默认 bottlepy 网络服务器的脚本? 谢谢。 UPD:现在
我一直使用 bluepill成功地守护简单的 Ruby 脚本。然而这一次,我有一个脚本,它也在加载 Rails 环境,因此我可以访问 Rails 应用程序及其各自模型的数据库连接。我使用的 bluep
我试图守护一些代码,但我遇到了一些麻烦。 如果我用 tklogger() 调用代码,它运行得很好。但是,如果我在守护程序上下文中调用它,我会得到以下跟踪信息: Traceback (most rece
我打算使用 systemd 将 celery 4.3.0 作为守护进程运行,但它给了我这个错误: 它会启动 worker 但会很快停止它们。但是,我可以通过键入以下命令手动运行工作人员: celery
我是一名优秀的程序员,十分优秀!