27

我将launchd配置为每天晚上18点在我的mac pro上启动一个命令,但它不起作用。

我想检查 launchd 是否已运行该命令。我尝试了系统控制台,没有发现任何有价值的东西。

我的 mac os 版本是 mac os x 10.8.3

我的 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>mytask</string>
    <key>Program</key>
    <string>/opt/local/bin/node</string>
    <key>ProgramArguments</key>
    <array>
        <string>/Users/xxx/My/task.js</string>
    </array>
    <key>StartCalendarInterval</key>
    <dict>
        <key>Hour</key>
        <integer>18</integer>
        <key>Minute</key>
        <integer>0</integer>
    </dict>
    <key>StandardOutPath</key>
    <string>/Users/xxx/launchd.stdout.log</string>
    <key>StandardErrorPath</key>
    <string>/Users/xxx/launchd.stderr.log</string>
</dict>
</plist>
4

1 回答 1

33

你定义StartCalendarInterval了,所以job在加载的时候就已经执行了,每天18:00都会执行。

查询 launchd(8) 以了解其退出状态:

launchctl list | grep mytask

这将返回一行:

<pid> <status> mytask

pid是一个数字时,作业当前正在运行。否则看一下status,这是程序的退出代码,在你的情况下是节点。退出代码 0 表示程序已成功完成或尚未启动。程序错误返回正数,而负数表示作业因信号而终止。

我认为这项工作失败了。您可能需要检查程序标准输出/错误。指定StandardOutPathStandardErrorPath做到这一点。这些文件的内容可能会告诉您程序失败的原因。

于 2013-05-24T04:40:17.807 回答