Частичное выполнение Launchctl - PullRequest
0 голосов
/ 08 ноября 2018

У меня есть launchdaemon, который вызывает сценарий оболочки, состоящий из вызовов других сценариев оболочки:

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>

launchdaemon явно запускается, потому что script_b.sh создает и называет новый каталог, и каталог успешно создается и заполняется. Однако script_c.sh не выполняется.

Я уже установил права владения / разрешения для launchdaemeon (644, root: wheel), поэтому я не уверен, что проблема связана с разрешениями. При запуске manager.sh из Терминала все сценарии ведут себя как положено.

Кроме того, launchdaemon / manager.sh успешно вызывал все 3 сценария, пока система не отключилась и не отключилась. Предприняты попытки вручную выгрузить и загрузить launchdaemon без видимых изменений.

...