微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

解决写入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

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐