部分启动执行

时间:2018-11-08 20:03:07

标签: automation launchd launchctl

我有一个启动守护程序,该守护程序调用由其他shell脚本的调用组成的shell脚本:

manager.sh:

#!/bin/sh

sh -x "$(dirname $0)"/script_a.sh
sh -x "$(dirname $0)"/script_b.sh
sh -x "$(dirname $0)"/script_c.sh

com.example.my

<?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.example.my</string>
    <key>KeepAlive</key>
    <false/>
    <key>RunAtLoad</key>
    <false/>
    <key>UserName</key>
    <string>root</string>
    <key>ProgramArguments</key>
    <array>
        <string>sh</string>
        <string>-x</string>
        <string>/path/to/manager.sh</string>
    </array>
    <key>StartCalendarInterval</key>
    <dict>
        <key>Hour</key>
        <integer>10</integer>
        <key>Minute</key>
        <integer>15</integer>
    </dict>
</dict>
</plist>

启动守护程序显然正在运行,因为script_b.sh创建并命名了一个新目录,并且该目录已成功创建并填充。但是,script_c.sh似乎没有执行。

我已经设置了launchdaemeon(644,root:wheel)的所有权/权限,所以我不确定问题是否是由于权限所致。从终端运行manager.sh,所有脚本的行为均符合预期。

此外,launchdaemon / manager.sh成功调用了所有三个脚本,直到系统断电并关闭。已经尝试手动卸载和加载启动守护程序,而没有明显的变化。

0 个答案:

没有答案