É possível parar um serviço através do launchd se o serviço for iniciado manualmente?

0

Eu estou usando o launchd para iniciar o mysql na inicialização, ele está funcionando bem. Eu sou capaz de parar e iniciar o serviço usando os comandos 'launchctl unload' e 'launchctl load'. Também posso iniciar o serviço digitando o comando 'mysqld_safe' no terminal. Mas, se eu parar o serviço através de 'launchctl stop' e depois iniciar o serviço através do comando 'mysqld_safe', não consigo parar o serviço através de 'launchctl stop'. Isso é possível? O que estou fazendo errado aqui?

Meu 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>

O comando usado para iniciar o mysql através do terminal é:

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
    
por KarthzDIGI 05.09.2013 / 11:13

2 respostas

0

Este é o comportamento pretendido. Emitir launchctl stop para um trabalho que não foi carregado não funciona.

    
por 05.09.2013 / 18:20
0

Eu tive que adicionar a seguinte linha:

<key>ExitTimeOut</key>       <integer>30</integer>

Se você seguir o error_log, verá que nada acontece até depois desse tempo limite. Você poderia tornar esse valor menor.

Você terá algo parecido com o seguinte

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

Por que as coisas não morrem antes do valor do tempo limite - eu não sei, mas eu tenho usado isso e é compatível com os comandos start / stop do mysql.server também.

    
por 13.09.2016 / 19:58