如何为Python脚本修复launchctl状态代码78?

时间:2019-06-01 08:08:24

标签: python python-3.x macos launchd launchctl

我正在尝试使用PRAW API托管一个机器人,以将每日的Wikipedia线程发布到/ r / Wikipedaily,并且我认为我会使用launchd / launchctl来安排每24小时运行一次的帖子。该脚本会启动(这是一个正在运行的launchctl进程),但是它始终具有状态代码78,以指示某些错误。

我尝试将plist文件放在LaunchAgents和LaunchDaemons中,用sudo启动它,在脚本和启动文件中都指定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帖子运行得很好,但是在控制台中启动并执行脚本失败,并显示以下错误消息:

  • 服务无法初始化:18C54:xpcproxy + 11287 [1534] [EB0A8C9B-6A9A-3296-B905-73527C966685]:0xd

  • 服务已退出,代码异常:78

它至少每分钟运行一次(根据控制台输出),但是不幸的是,它似乎是通用错误代码78,这对我来说并没有太多说明,而且我不确定xpcproxy行的用途。

希望对此有所帮助!预先感谢!

0 个答案:

没有答案