Можно ли остановить службу через launchd, если служба запускается вручную?
Я использую launchd для запуска mysql при загрузке, он работает нормально. Я могу остановить и запустить службу с помощью команд launchctl unload и launchctl load. Также я могу запустить службу, набрав команду "mysqld_safe" в терминале. Но если я остановлю службу с помощью 'launchctl stop', а затем запусту службу с помощью команды 'mysqld_safe', я не смогу остановить службу с помощью 'launchctl stop'. Это возможно? Что я здесь не так делаю?
Мой 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>mysql.service</string>
<key>ProgramArguments</key>
<array>
<string>/path/to/mysql/bin/mysqld_safe</string>
<string>--defaults-file=/path/to/mysql/my.cnf</string>
<string>--port=3306</string>
<string>--socket=/path/to/mysql/tmp/mysql.sock</string>
<string>--datadir=/path/to/mysql/data</string>
<string>--log-error=/path/to/mysql/data/mysqld.log</string>
<string>--pid-file=/path/to/mysql/data/mysqld.pid</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>KeepAlive</key>
<false/>
<key>UserName</key>
<string>_mysql</string>
<key>GroupName</key>
<string>_mysql</string>
<key>StandardOutPath</key>
<string>/tmp/mysql_start.out</string>
<key>StandardErrorPath</key>
<string>/tmp/mysql_start.err</string>
</dict>
</plist>
Команда, используемая для запуска mysql через терминал:
mysqld_safe --defaults-file=/path/to/mysql/my.cnf --port=3306 --socket=/path/to/mysql/tmp/mysql.sock --datadir=/path/to/mysql/data --pid-file=/path/to/mysql/data/mysqld.pid
2 ответа
Это намеренное поведение. Выдача launchctl stop
для работы, которая не была загружена, не работает.
Мне пришлось добавить следующую строку:
<key>ExitTimeOut</key> <integer>30</integer>
Если вы запишете error_log, вы увидите, что ничего не произойдет до истечения этого времени. Вы можете сделать это значение меньше.
Вы будете что-то вроде следующего
2016-09-13 13:42:09 14055 [Note] Giving 0 client threads a chance to die gracefully
2016-09-13 13:42:09 14055 [Note] Event Scheduler: Purging the queue. 0 events
2016-09-13 13:42:09 14055 [Note] Shutting down slave threads
2016-09-13 13:42:09 14055 [Note] Forcefully disconnecting 0 remaining clients
...
2016-09-13 13:42:10 14055 [Note] Shutting down plugin 'sha256_password'
2016-09-13 13:42:10 14055 [Note] Shutting down plugin 'mysql_old_password'
2016-09-13 13:42:10 14055 [Note] Shutting down plugin 'mysql_native_password'
2016-09-13 13:42:10 14055 [Note] Shutting down plugin 'binlog'
2016-09-13 13:42:10 14055 [Note] /usr/local/mysql-5.6.33-osx10.11-x86_64/bin/mysqld: Shutdown complete
Почему вещи не умирают до истечения времени ожидания - я не знаю, но я использовал это, и это также совместимо с командами запуска / остановки mysql.server.