You can change this value on the server by setting the max_allowed_packet‘ variable.

2 篇文章 0 订阅

You can change this value on the server by setting the max_allowed_packet’ variable.; nested exception is java.sql.BatchUpdateException: Packet for query is too large (5320443 > 4194304). You can change this value on the server by setting the max_allowed_packet’ variable

在系统执行推送订单,查询线上日志,会有这个错误信息,
MySQL根据配置文件会限制server接受的数据包大小

有时候大的插入和更新会被max_allowed_packet 参数限制掉,导致失败。

查看目前配置, Windows 系统 配置文件为 my.ini, max 系统 配置文件为 my.cnf

此处使用本地数据库操作:

下面展示一些 内联代码片

// A code block
  cmd 进入mysql bin 目录 --》

  登录本地 --》

  mysql -u root -p --》

  登录密码 --》

  show VARIABLES like ‘%max_allowed_packet%‘;

  显示的结果为:

  +----------------------------+------------+

  | Variable_name             | Value |

  +----------------------------+-----------+

  | max_allowed_packet     | 1048576|

  +----------------------------+-----------+

以上说明目前的配置是:1M

修改方法

// An highlighted block
  1) 方法1
可以编辑my.cnf来修改(windows下my.ini),[mysqld]段或者mysql的server配置段进行修改。

max_allowed_packet = 20M
如果找不到my.cnf可以通过

mysql --help | grep my.cnf
去寻找my.cnf文件。

2) 方法2
(很妥协,很纠结的办法)

进入mysql server

在mysql 命令行中运行

set global max_allowed_packet = 2*1024*1024*10
然后关闭掉这此mysql server链接,再进入。

show VARIABLES like ‘%max_allowed_packet%;
查看下max_allowed_packet是否编辑成功

经验总结:

在很多台机器上用方法一都没问题,但是个别订单在推送过程中,就回报后台异常,

使用命令行方式:set global max_allowed_packet = 16M;

也不行,但使用

set global max_allowed_packet = 210241024*10;
可以实现

mysql在执行单条大量数据的插入操作时,提示了如下的错误:

谷歌了下max_allowed_packet,发现mysql收到的packet大于max_allowed_packet时,就会报错并且关闭连接。这个packet查了几个地方都没有准确的中文定义,我暂且理解为单条sql语句吧。
通过工具或者命令行进入mysql服务,调用如下命令查看max_allowed_packet的值
show variables like ‘max_allowed_packet’;

结果是1048576=1024K=1M
通过如下命令增大max_allowed_packet的值,解决值过小导致的问题
set global max_allowed_packet = 1010241024
设置为10M,退出mysql,然后重新进入, 调用show variables like ‘max_allowed_packet’;查看是否修改成功

注意事项:
1、 max_allowed_packet的值最大为1G,设置的值必须为1024的倍数
2、设置完后,需要退出mysql,重新进入才能看到设置后的值

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值