Попытка понять состояние запуска демона - PullRequest
0 голосов
/ 25 апреля 2018

Я пытаюсь настроить демон launchd для агента Zabbix в macOS 10.13 High Sierra.

Сначала я устанавливаю Zabbix агент с:

brew install zabbix --without-server-proxy

Затем я создаю список свойств с именем com.zabbix.zabbix_agentd.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>AbandonProcessGroup</key>
        <true/>
        <key>GroupName</key>
        <string>zabbix</string>
        <key>KeepAlive</key>
        <dict>
                <key>SuccessfulExit</key>
                <false/>
        </dict>
        <key>Label</key>
        <string>com.zabbix.zabbix_agentd</string>
        <key>ProgramArguments</key>
        <array>
                <string>/usr/local/sbin/zabbix_agentd</string>
                <string>-c</string>
                <string>/opt/zabbix/zabbix_agentd.conf</string>
        </array>
        <key>RunAtLoad</key>
        <true/>
        <key>StandardErrorPath</key>
        <string>/var/log/zabbix/zabbix_agentd.error.log</string>
        <key>StandardOutPath</key>
        <string>/var/log/zabbix/zabbix_agentd.stdout.log</string>
        <key>UserName</key>
        <string>zabbix</string>
</dict>
</plist>

Я загружаю это с:

sudo launchctl load ./com.zabbix.zabbix_agentd.plist

Теперь я вижу, что демон выполнил то, что ожидал:

ps ax | grep zabbix_agentd | grep -v grep

Я вижу 6 процессов zabbix. 1 сборщик, 3 прослушивателя, 1 активная проверка и процесс, который запустил демон запуска:

8931   ??  S      0:00.01 /usr/local/sbin/zabbix_agentd -c /opt/zabbix_agentd.conf

Но когда я запускаю эту команду:

launchctl print system/com.zabbix.zabbix_agentd | grep state

Я получаю этот вывод:

state = waiting

Я ожидал увидеть состояние = выполняется ... Почему эта команда говорит мне, что демон ожидает, когда у него 6 запущенных процессов?

Это "работает как задумано" или я что-то не так сделал?

1 Ответ

0 голосов
/ 25 апреля 2018

Это своего рода «работает как задумано», но я бы сказал, что это результат философского конфликта между zabbix и launchd о том, как должны работать демоны.

Когда вы запускаете zabbix_agentd, он «демонизирует»"сам по себе, что означает, что он запускает фактический процесс-демон как фоновый подпроцесс, а затем родительский процесс завершается;с этого момента процесс демона (и любые подпроцессы, которые он запускает) выполняется в значительной степени независимо от того, что их запустило.Это в значительной степени традиционный способ работы демонов Unix.

launchd, с другой стороны, написан так, чтобы ожидать, что демоны, которым он управляет, остаются на переднем плане и выполняются непосредственно под ним;это дает launchd гораздо больше возможностей для мониторинга и управления его демонами, чем если бы они дистанцировались от launchd.

Это обычный конфликт между традиционными демонами unix и launchd, и существует два способа его решения:либо заставьте демона работать на переднем плане (то есть, соблюдайте способ запуска launchd), либо скажите launchd не беспокоиться о том, что демон, похоже, завершил работу.zabbix_agentd, похоже, не имеет ничего подобного опции --nodaemon (в соответствии с этими документами ), поэтому вы должны адаптировать launchd (обновление: в более новых версиях, см. ниже).Стандартный способ сделать это, в значительной степени то, что у вас есть в вашем .plist, - это добавить ключи AbandonProcessGroup и KeepAlive, чтобы сообщить launchd не паниковать, когда (насколько он может судить) демон выходит.Это работает, но это означает, что launchd не может сказать, что на самом деле происходит с демоном, что приводит к странным результатам, которые вы видите.

ОБНОВЛЕНИЕ: Я просматривал старую версию zabbix_agentd.Стефан заметил, что опция -f (или --foreground) была добавлена ​​в zabbix_agentd в версии 3.0 .При этом я бы порекомендовал добавить --foreground в массив ProgramArguments, заменить словарь KeepAlive простым <true/> (это указывает launchd на автоматический перезапуск демона, если он по какой-либо причине завершает работу), и удаление<key>AbandonProcessGroup</key><true/> (эта опция определяет, будет ли launchd очищать оставшиеся подпроцессы, если основной процесс демона завершится / завершится сбоем).Результат должен выглядеть примерно так:

<?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>GroupName</key>
        <string>zabbix</string>
        <key>Label</key>
        <string>com.zabbix.zabbix_agentd</string>
        <key>ProgramArguments</key>
        <array>
                <string>/usr/local/sbin/zabbix_agentd</string>
                <string>-c</string>
                <string>/opt/zabbix/zabbix_agentd.conf</string>
                <string>--foreground</string>
        </array>
        <key>RunAtLoad</key>
        <true/>
        <key>KeepAlive</key>
        <true/>
        <key>StandardErrorPath</key>
        <string>/var/log/zabbix/zabbix_agentd.error.log</string>
        <key>StandardOutPath</key>
        <string>/var/log/zabbix/zabbix_agentd.stdout.log</string>
        <key>UserName</key>
        <string>zabbix</string>
</dict>
</plist>
...