MySQL сервер исчез после обновления Homebrew

Я только что сделал brew upgrade в PHP 7.2.8 и MySQL 8.0.12. После этого попытка подключения к MySQL из сценария PHP (из Bash) прекращается через 10 секунд (значение таймаута MySQL по умолчанию).

new PDO("mysql:host=localhost;dbname=foo;charset=utf8", "user", "pass");

[2006] MySQL server has gone away

Все в моей среде кажется нормальным. Я ничего не изменил в моей настройке. Подключение к MySQL из Bash работает нормально. Как мне восстановить доступ к MySQL из PHP?

$ php -i | grep php.ini
Configuration File (php.ini) Path => /usr/local/etc/php/7.2
Loaded Configuration File => /usr/local/etc/php/7.2/php.ini

$ tail /usr/local/etc/php/7.2/php.ini
mysql.default_socket = /tmp/mysql.sock
pdo_mysql.default_socket = /tmp/mysql.sock

$ ls /tmp/mysql*
srwxrwxrwx  0 /tmp/mysql.sock
-rw-------  5 /tmp/mysql.sock.lock
srwxrwxrwx  0 /tmp/mysqlx.sock
-rw-------  6 /tmp/mysqlx.sock.lock

$ mysql
Welcome to the MySQL monitor.
mysql> show variables like '%socket%';
+-----------------------------------------+------------------+
| mysqlx_socket                           | /tmp/mysqlx.sock |
| socket                                  | /tmp/mysql.sock  |
+-----------------------------------------+------------------+

2 ответа

Решение

Решение: добавьте это в ваш конфигурационный файл MySQL (my.cnf):

[mysqld]
default_authentication_plugin=mysql_native_password

Руководство по PHP:

MySQL 8 по умолчанию caching_sha2_password, плагин, который не распознается старыми версиями PHP. Вместо этого измените его, установив default_authentication_plugin=mysql_native_password в my.cnf, caching_sha2_password Плагин будет поддерживаться в будущем выпуске PHP.

Я надеюсь, что это избавит других от головной боли и времени.

Вот решение, которое не требует изменения конфигурации аутентификации по умолчанию.

mysql> create user 'username'@'host' identified with mysql_native_password by 'password';

Ссылки на MySQL 8.0: СОЗДАТЬ Синтаксис ПОЛЬЗОВАТЕЛЯ и Синтаксис ПОЛЬЗОВАТЕЛЬСКОГО ПОЛЬЗОВАТЕЛЯ

После обновления PHP для аутентификации SHA-256 вы можете "изменить пользователя", чтобы снова идентифицировать себя с помощью caching_sha2_password.

Другие вопросы по тегам