Я бы хотел запустить сервер MySQL при запуске. Это было возможно в Маверикс, но, похоже, он не работал над Йосемити.
edit: похоже, это работает и с El Capitan
Я бы хотел запустить сервер MySQL при запуске. Это было возможно в Маверикс, но, похоже, он не работал над Йосемити.
edit: похоже, это работает и с El Capitan
@dcc был очень близок. Это то, как MySQL снова запускается в Yosemite:
com.mysql.mysql.plist
в /Library/LaunchDaemons
:
<?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>KeepAlive</key>
<true/>
<key>Label</key>
<string>com.mysql.mysqld</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/mysql/bin/mysqld_safe</string>
<string>--user=mysql</string>
</array>
</dict>
</plist>
Кроме того, я изменил разрешения на основе этого ответа
sudo chown root:wheel /Library/LaunchDaemons/com.mysql.mysql.plist
sudo chmod 644 /Library/LaunchDaemons/com.mysql.mysql.plist
Наконец, я запустил эту команду
sudo launchctl load -w /Library/LaunchDaemons/com.mysql.mysql.plist
Если у вас есть какие-либо дополнения, пожалуйста, поделитесь ими!
Я выполнил @revaxarts направления и попытался выполнить команду
sudo launchctl load -w /Library/LaunchDaemons/com.mysql.mysql.plist
была задана ошибка:
/Library/LaunchDaemons/com.mysql.mysql.plist: Недопустимый список свойств
После того, как я поцарапал себе голову на минуту, я обнаружил, что удаление объявления DOCTYPE DTD вверху заставило ошибку уйти и после перезагрузки mySQL-сервер действительно работает.
Итак, мой XML выглядит так:
<?xml version="1.0" encoding="UTF-8"?>
<plist version="1.0">
<dict>
<key>KeepAlive</key>
<true/>
<key>Label</key>
<string>com.mysql.mysqld</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/mysql/bin/mysqld_safe</string>
<string>--user=mysql</string>
</array>
</dict>
</plist>
Если вы установили mysql с homebrew, вы можете получить инструкции по его автозапуску, набрав brew info mysql
.
Например, вывод на моем компьютере:
To have launchd start mysql at login:
ln -sfv /usr/local/opt/mysql/*.plist ~/Library/LaunchAgents
Then to load mysql now:
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.mysql.plist
Создайте /Library/LaunchDaemons/com.mysql.mysql.plist
и сохраните его со следующим plist:
<!--?xml version="1.0" encoding="UTF-8"?-->
<plist version="1.0">
<dict>
<key>KeepAlive</key>
<true>
<key>Label</key>
<string>com.mysql.mysqld</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/mysql/bin/mysqld_safe</string>
<string>--user=mysql</string>
</array>
</true>
</dict>
</plist>
Затем загрузите вновь созданный файл plist
sudo launchctl load -w /Library/LaunchDaemons/com.mysql.mysql.plist
Эта статья поможет мне решить проблему с недопустимой ошибкой. Исправленный слой, который я использовал ниже.
Как узнать, какая строка файла 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>KeepAlive</key>
<true/>
<key>Label</key>
<string>com.mysql.mysqld</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/mysql/bin/mysqld_safe</string>
<string>--user=mysql</string>
</array>
</dict>
</plist>
Ни один из других предоставленных ответов не работал для автоматического запуска моего сервера MySQL. Я выполнил инструкции из справочника MySQL 5.6, и он, наконец, автоматически запускается! Создайте файл /Library/LaunchDaemons/com.oracle.oss.mysql.mysqld.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>com.oracle.oss.mysql.mysqld</string>
<key>ProcessType</key> <string>Interactive</string>
<key>Disabled</key> <false/>
<key>RunAtLoad</key> <true/>
<key>KeepAlive</key> <true/>
<key>SessionCreate</key> <true/>
<key>LaunchOnlyOnce</key> <false/>
<key>UserName</key> <string>_mysql</string>
<key>GroupName</key> <string>_mysql</string>
<key>ExitTimeOut</key> <integer>600</integer>
<key>Program</key> <string>/usr/local/mysql/bin/mysqld</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/mysql/bin/mysqld</string>
<string>--user=_mysql</string>
<string>--basedir=/usr/local/mysql</string>
<string>--datadir=/usr/local/mysql/data</string>
<string>--plugin-dir=/usr/local/mysql/lib/plugin</string>
<string>--log-error=/usr/local/mysql/data/mysqld.local.err</string>
<string>--pid-file=/usr/local/mysql/data/mysqld.local.pid</string>
<string>--port=3306</string>
</array>
<key>WorkingDirectory</key> <string>/usr/local/mysql</string>
</dict>
</plist>
И запустите следующие команды после создания файла:
cd /Library/LaunchDaemons
sudo launchctl load -F com.oracle.oss.mysql.mysqld.plist
Когда я использовал plist, предложенный в более ранних ответах, я изменил пользователя на _mysql для моей системы, но кнопка "Stop MySQL Server" в панели предпочтений MySQL больше не работала. Клавиша KeepAlive
заставит процесс запуска снова сразу после нажатия кнопки "Стоп". Я использовал ключ RunAtLoad
, чтобы запустить его при перезагрузке, но позвольте кнопке в панели продолжить работу.
<?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>RunAtLoad</key>
<true/>
<key>Label</key>
<string>com.mysql.mysqld</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/mysql/bin/mysqld_safe</string>
<string>--user=_mysql</string>
</array>
</dict>
</plist>
Затем, как и в других ответах, побежал:
sudo launchctl load -w /Library/LaunchDaemons/com.mysql.mysql.plist
Теперь MySQL запускается при перезагрузке, но панель MySQL в Системных настройках все еще работает. Я управляю El Capitan, 10.11.2