Список OSX launchctl не находит мой plist

Список OSX launchctl не находит мой plist

Я создал файл /System/Library/LaunchDaemons/com.rundeckd.plistс таким содержанием:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Disabled</key>
    <true/>
    <key>Label</key>
    <string>com.rundeckd</string>
    <key>ProgramArguments</key>
    <array>
        <string>/test/rundeck/server/sbin/rundeckd</string>
        <string>start</string>
    </array>
    <key>KeepAlive</key>
    <true/>

    <key>StandardOutPath</key>
    <string>/test/rundeck/var/log/launchd_out.log</string>
    <key>StandardErrorPath</key>
    <string>/test/rundeck/var/log/launchd_sdd.log</string>
    <key>Debug</key>
    <true/>
</dict>
</plist>

Однако sudo launchctl list не отображает этот rundeckd.

почему?

Кроме того, rundeckd не запускает его во время загрузки, а файлы журналов не создаются. (обратите внимание, я изменил rundeckd, чтобы требуемая переменная окружения $RDECK_BASE была жестко закодирована в скрипте)

Обновлять

Гордон Дэвиссон, я изменил plist, как вы сказали, и, не изменяя скрипт rundeckd, я получаю следующее:

nohup: can't detach from console: Inappropriate ioctl for device

затем я попробовал добавить опцию «launchd» в rundeckd (в настоящее время там были start, stop и status), как показано ниже:

launchd() {
    echo "%s" "launchd $prog: "
    touch $LOK_FILE
    $rundeckd 2>&1 >>$RDECK_BASE/var/log/service.log &
    PID=$!
    echo $PID > $PID_FILE
    fg $PID  # block until it is stopped
}

но я получаю ошибку fg: no job control, так как, по-видимому, я не могу запустить «fg», потому что это не интерактивная оболочка. https://stackoverflow.com/questions/11821378/что-означает-bashno-job-control-in-this-shell

решение1

Ваш launchd plist помечает элемент как отключенный:

    <key>Disabled</key>
    <true/>

Чтобы запустить его, вам нужно либо изменить его на <false/>, либо переопределить его с помощью sudo launchctl load -w /System/Library/LaunchDaemons/com.rundeckd.plist(что -wделает его постоянным).

Также, изменили ли вы скрипт, чтобы избежать демонизации самого себя? Если нет, вам нужно будет изменить <key>KeepAlive</key>на <false/>, и добавить <key>AbandonProcessGroup</key><true/>.

Кстати, вы также можете определить переменные среды в .plist вместо того, чтобы изменять скрипт, чтобы включить их:

    <key>EnvironmentVariables</key>
    <dict>
        <key>RDECK_BASE</key>
        <string>/Users/david/bin/rundeck</string>
    </dict>

И наконец, я бы рекомендовал изменить метку и имя файла — они должны быть основаны наобратное соглашение об именовании DNS, поэтому, если вы не являетесь владельцем домена rundeckd.com, вам не следует использовать его в качестве метки или префикса метки. Для самодельных записей, подобных этой, я рекомендую использовать префикс "local", т. е. "local.rundeckd".

Обновление: управление заданиями доступно только в интерактивных оболочках; используйте wait $PIDвместо fg $PID.

решение2

https://gist.github.com/dportabella/7714449

$RDECK_BASE/server/sbin/rundeck_launchdскрипт для запуска rundeck без отправки процесса в фоновый режим (требуется для OSX Launchd).

/System/Library/LaunchAgents/david.rundeck.plistэто файл конфигурации для настройки rundeck как службы запуска Mac OSX. Вам необходимо изменить этот файл в соответствии с вашими потребностями. в этом примере RDECK_BASE — это /Users/david/bin/rundeck.

После установки этих двух файлов перезагрузите компьютер, и rundeck запустится во время загрузки.

Затем вы можете остановить, запустить и просмотреть статус службы Rundeck:

$ launchctl start david.rundeck
$ launchctl stop david.rundeck
$ launchctl list david.rundeck

(этот скрипт основан на скрипте $RDECK_BASE/server/sbin/rundeckd)

Файл$RDECK_BASE/server/sbin/rundeck_launchd

#!/bin/bash 
#
# rundeck_launchd    Startup script for the RunDeck Launcher install
#   paramaters:
#     - env vars: [RDECK_BASE, RDECK_PORT, RDECK_LAUNCHER]
#     - standard RDECK_PORT values: [http: 4440, https: 4443]

export RDECK_BASE=${0%/*/*/*}

# RDECK_BASE must be set and exist
[ -z "$RDECK_BASE" -o ! -d "$RDECK_BASE" ] && {
    echo "RDECK_BASE not set or does not exist" ;
    exit 1 ;
}

# Source installation profile
. $RDECK_BASE/etc/profile

# Get the Launcher Jar path
[ -z "$RDECK_LAUNCHER" ] && {
    # Defaults to location of first startup
    RDECK_LAUNCHER=$(ls $RDECK_BASE/rundeck-launcher-*.jar)
}
[ -r "$RDECK_LAUNCHER" ] || {
    echo "RDECK_LAUNCHER not found: $RDECK_LAUNCHER" 
    exit 1;
}

# lookup the server port from the tools config file
RDECK_PORT=`awk '/framework.server.port/ {print $3}' $RDECK_BASE/etc/framework.properties`

# set the ssl opts if https is configured
SSL_OPTS=
proto=$(awk '/framework.server.url = / {split($3, a, ":"); print a[1]}' $RDECK_BASE/etc/framework.properties)
[ "${proto:-http}" == "https" ] && {
   SSL_OPTS="-Drundeck.ssl.config=$RDECK_BASE/server/config/ssl.properties"
}

rundeckd="${JAVA_HOME}/bin/java ${RDECK_JVM} -Dserver.http.port=${RDECK_PORT:=4440} $SSL_OPTS -jar ${RDECK_LAUNCHER}"

[ -w $RDECK_BASE/var ] || {
    echo "RDECK_BASE dir not writable: $RDECK_BASE" 
    exit 1 ;
}

mkdir -p $RDECK_BASE/var/run
mkdir -p $RDECK_BASE/var/log
mkdir -p $RDECK_BASE/var/lock/subsys

$rundeckd 2>&1 >>$RDECK_BASE/var/log/service.log

Файл/System/Library/LaunchAgents/david.rundeck.plist

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Label</key>
    <string>david.rundeck</string>
    <key>ProgramArguments</key>
    <array>
        <string>/Users/david/bin/rundeck/server/sbin/rundeck_launchd</string>
    </array>
    <key>KeepAlive</key>
    <true/>
    <key>RunAtLoad</key>
    <true/>
    <key>UserName</key>
    <string>david</string>
    <key>Debug</key>
    <true/>
</dict>
</plist>

Связанный контент