自制软件升级后,MySQL服务器已消失

时间:2018-08-04 08:00:20

标签: php mysql homebrew

我刚刚对PHP 7.2.8和MySQL 8.0.12做了brew upgrade。此后,尝试从PHP脚本(从Bash)连接到MySQL会在10秒(默认的MySQL超时值)后超时。

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

[2006] MySQL server has gone away

我的环境中的一切似乎都很正常。我没有更改设置中的其他任何内容。从Bash连接到MySQL可以正常工作。如何从PHP重新获得MySQL访问权限?

$ 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 个答案:

答案 0 :(得分:3)

解决方案:将其添加到您的MySQL配置文件( import com.fasterxml.jackson.annotation.JsonFormat; class YourObjectClass { @JsonFormat(shape=JsonFormat.Shape.STRING) private BigDecimal yourVariable; } ):

my.cnf

PHP manual

  

MySQL 8默认为[mysqld] default_authentication_plugin=mysql_native_password ,这是旧版PHP无法识别的插件。   而是通过在caching_sha2_password中设置default_authentication_plugin=mysql_native_password来更改它。的   未来的PHP将支持my.cnf插件   释放。

我希望这可以节省其他人的头痛和时间。

答案 1 :(得分:1)

这是不需要更改默认身份验证配置的解决方案。

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

MySQL 8.0参考:CREATE USER SyntaxGRANT USER Syntax

一旦PHP更新为SHA-256身份验证,您就可以“更改用户”身份,再次使用caching_sha2_password进行标识。