解决写入MySQL报错超出max_allowed_packet的异常

问题描述

 max_allowed_packet是指mysql服务器端和客户端在一次传送数据包的过程当中最大允许的数据包大小。

问题分析

大数据的插入和更新会被max_allowed_packet 参数限制掉,从而导致数据库的数据插入或者更新失败。

1.将本地数据库迁移到远程数据库时运行sql错误。错误信息是max_allowed_packet

2.插入数据时某个字段数据过于庞大(使用Elmentui编辑器自带的图片加密,图片过多,地址超级长,最好用的时候改成自定义的),会报
Packet for query is too large (20682943>1048576). You can change this value on the server by setting the max_allowed_packet’ variable.

解决方案

查看最大允许包数

mysql> show variables like 'max_allowed_packet';
或者
mysql> select @@max_allowed_packet;

max_allowed_packet 如果不设置,默认值在不同的 MySQL 版本表现不同,有的版本默认1M,有的版本默认4M。

1.配置文件持久化修改

vim /etc/my.cnf
[mysqld]
max_allowed_packet = 100M

tip:修改配置文件以后,需要重启mysql服务才能生效。

校验修改是否成功命令
show variables like '%max_allowed_pack%';

 

2.命令行临时修改,(重启后失效)

set global max_allowed_packet = 100 * 1024 * 1024;
mysql> exit
重新登录执行命令
mysql> select @@max_allowed_packet;

tip:1.命令行修改时,不能用M、G,只能这算成字节数设置。配置文件修改才允许设置M、G单位。

2.命令行修改之后,需要退出当前回话(关闭当前mysql server链接),然后重新登录才能查看修改后的值。通过命令行修改只能临时生效,下次数据库重启后又复原了。

3.max_allowed_packet 最大值是1G(1073741824),如果设置超过1G,查看最终生效结果也只有1G。

[mysqld]
max_allowed_packet = 1G

 

笔者: 沙漏倒装回忆1024

出处https://www.cnblogs.com/lpan1024/

版权所有,欢迎保留原文链接进行转载!

请点赞关注留言,如果有任何建议也可以留言,因为我会回复每一条评论,感谢阅读。

posted @ 2022-09-14 23:48  沙漏倒装回忆1024  阅读(630)  评论(0编辑  收藏  举报