1.因为mysql有一个max_allowed_packet变量,可以控制其通信缓冲区的最大长度,所以当缓冲区的大小太小的时候,导致某些查询和插入操作报错。
解决方法如下,
2.解决方法
2.1 修改配置文件
a .可以编辑my.cnf来修改(windows下my.ini),在[mysqld]段或者mysql的server配置段进行修改。
max_allowed_packet = 20M
b.如果找不到my.cnf可以通过
mysql --help | grep my.cnf
去寻找my.cnf文件。
c.重启mysql服务
d.执行命令查看是否成功
SHOW VARIABLES LIKE '%max_allowed_packet%'
2.2 使用命令修改max_allowed_packet 大小
a.执行命令
SET GLOBAL max_allowed_packet = 2*1024*1024*10 -- 单位为B
b.然后关闭掉这此链接,再进入执行命令
SHOW VARIABLES LIKE '%max_allowed_packet%'
3.两种方法比较
根据自身经验和网上论坛帖子,第二种方法出现问题的概率相对较小。第一种我在最近的一次设置上,不起作用,使用第二种方式就没有问题,
4.常见的问题
a.通过修改配置文件之后 max_allowed_packet 的值 不定期的自动改变, 网上对于这种解释是因为mysql内存不足,导致的
b.修改配置文件之后 max_allowed_packet 的值 之后,没有生效,重启也没有生效,一种问题是本地的客户端与mysql服务器没有断开查询的,重新链接,查看是否生效,如果没有生效,使用第二种方式,进行修改
————————————————
版权声明:本文为CSDN博主「算.子」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/wangshuai6707/article/details/50455421