python - 如何修复 Python 脚本的 launchctl 状态码 78?
问题描述
我正在尝试使用 PRAW API 来托管一个机器人,用于将每日 Wikipedia 线程发布到 /r/Wikipedaily,我想我会使用 launchd/launchctl 来安排帖子每 24 小时运行一次。脚本启动(它是一个正在运行的 launchctl 进程),但它始终具有状态代码 78 以表示某些错误。
我尝试将 plist 文件放在 LaunchAgents 和 LaunchDaemons 中,使用 sudo 启动它,在脚本和 launchd 文件中指定 Python env 的路径,所有 3 都导致相同的错误代码。我认为这不是 Python 脚本本身的问题,因为从命令行手动运行它似乎工作正常。
我的直觉是问题出在 plist 文件本身,与 Python 环境规范或文件/目录的权限有关。我通过 chmod +x 授予了 Python 脚本权限,但这可能还不够。
这是 plist 文件(出于调试目的,StartInterval 设置为 60 而不是 86400,无论如何都不起作用):
com.nathansbud.wikipedaily.plist:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>com.nathansbud.wikipedaily</string>
<key>Program</key>
<string>/Users/zackamiton/Code/Wikipedaily/main.py</string>
<key>ProgramArguments</key>
<array>
<string>/Users/zackamiton/Code/Wikipedaily/main.py</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>StartInterval</key>
<integer>60</integer>
<key>StandardErrorPath</key>
<string>/var/log/wikipedaily.log</string>
<key>StandardOutPath</key>
<string>/var/log/wikipedaily.log</string>
<key>WorkingDirectory</key>
<string>/Users/zackamiton/Code/Wikipedaily/</string>
</dict>
</plist>
从命令行运行它,Reddit 帖子工作得很好,但是让 launchd 执行脚本失败,并在控制台中显示以下错误消息:
服务无法初始化:18C54:xpcproxy + 11287 [1534][EB0A8C9B-6A9A-3296-B905-73527C966685]:0xd
服务退出异常代码:78
它至少每分钟运行一次(根据控制台输出),但不幸的是,78 似乎是通用错误代码,对我来说并没有太多说明,而且我不确定 xpcproxy 线的含义。
对此有任何帮助将不胜感激!提前致谢!
解决方案
推荐阅读
- node.js - mac外部驱动器上的create-react-app不断刷新页面
- javascript - 如何将数据从我的 HTML/JS 程序传输到 firebase 数据库?
- python - 如何从已经存在的列表(discord.py 相关)中创建/添加到 json 对象数组?
- visual-c++ - 强制 NVCC 直接进入链接阶段
- php - 在php中每两个月更改一次日历
- assembly - x86 或类似程序集中的内存分配
- javascript - 使用 Cookies 来存储个性化信息或设置偏好:当用户登录到新设备时它是否仍然存在
- r - How to make a stacked-bar plot of a confusion matrix
- bash - How i can use sed or another to replace specific string in Makefile
- r - Dplyr group_modify 和匿名函数