背景
- 近期对负责项目,配置了一套 主从复制的
MySQL
集群
使用了中间件mycat
但测试发现,替换了原来的数据连接后,会出现Packets out of order
的报错
同时注意到,有的框架代码中竟然也会失效,比如 controller 类中,获取
$request->all()
竟然变空了
分析、排查
- 首先,切换
mycat
后,程序报错的一段源码如下:
[2024-07-04 10:48:58] local.ERROR: Packets out of order. Expected 1 received 5. Packet size=85 (SQL: select `cms_password_resets`.* where `memberid` = 122 and `cms_password_resets`.`deleted_at` is null order by `id` desc) at D:\\phpstudy_pro\\WWW\\projzqb1b\\vendor\\laravel\\framework\\src\\Illuminate\\Database\\Connection.php:664, ErrorException(code: 0): Packets out of order. Expected 1 received 5. Packet size=85 at D:\\phpstudy_pro\\WWW\\projzqb1b\\vendor\\laravel\\framework\\src\\Illuminate\\Database\\Connection.php:332)
-
首先根据百度经验,提示需要修改
mysql.cnf
中的max_allowed_packet
参数
但是,发现不应该是这个问题,毕竟不使用 mycat 时不会出现问题 -
继续查找发现,这个问题的原因很可能是数据库配置参数的 【预处理】问题
设置database.php
中的options
的预处理可以解决报错 (但是查询出来的数据全部转为了字符串)
附录
- 关于 MySQL 的 Packets out of order 问题
- thinkphp5+mycat 查询出现 Packets out of order. Expected 4 received 0. Packet size=10
- Laravel连接mycat报错?