问题描述
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