关于java web程序中数据包太大设置mysql 中max_allowed_packet变量值

max_allowed_packet 默认值为1024,也就是1M,有的时候,我们在操作数据库的时,因为数据包过大查过了max_allowed_packet的最大值而导致程序异常。通常情况下我们是通过修改mysql的配置文件来修改其大小。下面以我程序的环境为例继续相关操作。


我的程序和数据库是分离的,程序运行在本机,mysql数据库部署在windows server 2012服务器中,通过navicat来远程连接数据库。


1.打开navicat 连接数据库,新建查询命令,输入命令  show VARIABLES like '%max_allowed_packet%'; 发现max_allowed_packet为1024

2、通过vnc远程登陆服务器,打开mysql的安装目录,打开my.ini 找到 max_allowed_packet 将其值修改大点,比如20M。如果没有max_allowed_packet,则在该文件的末尾

添加

[mysqld]

max_allowed_packet = 20M

关闭保存my.ini文件,重启mysql。

但是这个时候我本机的程序重新运行发现还是报查询的数据包大于max_allowed_packet 的最大值。

在navicat 查询中运行  show VARIABLES like '%max_allowed_packet%'; 发现max_allowed_packet还是为1024,没有更改过来。这个时候要重启服务器上的mysql,再一次在navicat中运行,就改过来了。然后运行程序就可以了。


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值