ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

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

2022-09-15 00:01:43  阅读:260  来源: 互联网

标签:max allowed packet 修改 报错 1G mysql


问题描述

 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

 

标签:max,allowed,packet,修改,报错,1G,mysql
来源: https://www.cnblogs.com/lpan1024/p/16695041.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有