mysql的设置参数中max_allowed_packet过小导致操作异常

本文介绍了解决MySQL中max_allowed_packet参数导致的问题的方法。包括通过配置文件进行永久性修改及使用命令行实现临时调整。并提供了详细的步骤说明及注意事项。

永久性解决方案:
修改方法1(配置文件持久化修改):
vim /etc/my.cnf
[mysqld]
max_allowed_packet = 100M

注意:修改配置文件以后,需要重启mysql服务才能生效。

临时解决方案,修改该值
show variables like ‘max_allowed_packet’;

set global max_allowed_packet = 10 * 1024 * 1024;

但是重启Mysql还是会恢复到默认值,所以需要写在配置文件当中

注意:

1.命令行修改时,不能用M、G,只能这算成字节数设置。配置文件修改才允许设置M、G单位。

2.命令行修改之后,需要退出当前回话(关闭当前mysql server链接),然后重新登录才能查看修改后的值。通过命令行修改只能临时生效,下次数据库重启后又复原了。

3.max_allowed_packet 最大值是1G(1073741824),如果设置超过1G,查看最终生效结果也只有1G。

排查过程


root     32270     1  0 Feb22 ?        00:00:00 /bin/sh /mariadb/mysql/bin/mysqld_safe --defaults-file=/etc/my10.3.cnf --user=mysql --datadir=/mariadb/mysql/data
mysql    32398 32270  0 Feb22 ?        00:12:58 /mariadb/mysql/bin/mysqld --defaults-file=/etc/my10.3.cnf --basedir=/mariadb/mysql --datadir=/mariadb/mysql/data --plugin-dir=/mariadb/mysql/lib/plugin --user=mysql --log-error=/mariadb/mysql/data/error.log --pid-file=/mariadb/mysql/mysql.pid --socket=/mariadb/mysql/mysql.sock --port=3306

url="jdbc:mariadb://10.1.1.19:3306/certtrust?useUnicode=true&characterEncoding=UTF-8"


[root@vm-11a-01m93 etc]# ifconfig
eth0      Link encap:Ethernet  HWaddr FA:16:3E:E6:F6:38  
          inet addr:10.1.1.19  Bcast:10.1.1.255  Mask:255.255.255.0
          inet6 addr: fe80::f816:3eff:fee6:f638/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1450  Metric:1
          RX packets:244383612 errors:0 dropped:0 overruns:0 frame:0
          TX packets:241543679 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:117353719738 (109.2 GiB)  TX bytes:101645269028 (94.6 GiB)

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:77623616 errors:0 dropped:0 overruns:0 frame:0
          TX packets:77623616 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:14628056786 (13.6 GiB)  TX bytes:14628056786 (13.6 GiB)
		  

错误信息

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.springframework.jdbc.UncategorizedSQLException: 
### Error querying database.  Cause: java.sql.SQLException: (conn=9760) query size (2079) is >= to max_allowed_packet (1024)
### The error may exist in com/itrus/newportal/certtrustweb/daoext/EnterpriseUserInfoMapperExt.xml
### The error may involve defaultParameterMap
### The error occurred while setting parameters
### SQL: SELECT                    ent.id AS ent_id,        ent.email,        ent.`name`,        ent.phone_number,        ent.user_additional_field1,        ent.user_additional_field2,        ent.user_additional_field3,        ent.user_additional_field4,        ent.user_additional_field5,        ent.user_additional_field6,        ent.user_additional_field7,        ent.user_additional_field8,        ent.user_additional_field9,        ent.user_additional_field10,        ent.user_country,        ent.user_description,        ent.user_dns,        ent.user_ip,        ent.user_locality,        ent.user_name,        ent.user_organization,        ent.user_orgunit,        ent.user_serialnumber,        ent.user_state,        ent.user_street,        ent.user_surname,        ent.user_title,        ent.product_id,        ent.project_id,        ent.create_time,           uc.id AS uc_id,           uc.key_sn,           uc.cert_status,           uc.cert_cn,           uc.cert_end_time,           uc.cert_make_time,           uc.cert_revoke_reason,           uc.cert_revoke_time,           uc.cert_sn,           uc.cert_source,           uc.cert_start_time,           uc.issuer_dn,           uc.modify_time,           uc.cert_info_id,           uc.ra_account_id               FROM        enterprise_user_info AS ent         LEFT JOIN cert_belong_info AS cbi ON ent.id = cbi.enterprise_user_info_id         LEFT JOIN user_cert AS uc ON cbi.user_cert_id = uc.id          WHERE (cbi.newest_cert = TRUE OR cbi.enterprise_user_info_id IS NULL)                                                                                                                                                                                                                                                                                                                                                                                                          AND ent.product_id = ?                                           AND ent.project_id = ?          ORDER BY ent.create_time DESC                       limit ?,?
### Cause: java.sql.SQLException: (conn=9760) query size (2079) is >= to max_allowed_packet (1024)
; uncategorized SQLException for SQL []; SQL state [HY]; error code [0]; (conn=9760) query size (2079) is >= to max_allowed_packet (1024); nested exception is java.sql.SQLException: (conn=9760) query size (2079) is >= to max_allowed_packet (1024)
	org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:973)
	org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:863)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:661)
	org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:837)
	javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
	org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
	com.itrus.newportal.filter.SecureFilter.doFilter(SecureFilter.java:231)
	org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
	org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:108)
### 如何在 Windows 环境下设置 MySQL 的 `max_allowed_packet` 参数 #### 方法一:通过配置文件修改 可以在 MySQL 安装目录下的 `my.ini` 文件中进行配置。如果该文件不存在,则需要手动创建。 1. **定位到 MySQL 安装路径** 找到 MySQL 的安装目录,通常位于 `C:\Program Files\MySQL\MySQL Server X.X` 或其他自定义位置。 2. **编辑或新建 `my.ini` 文件** 如果存在 `my.ini` 文件则直接打开;如果没有,则需手动创建并保存为 `my.ini`。 3. **添加或修改 `[mysqld]` 部分的内容** 在 `[mysqld]` 节点下加入以下内容: ```ini [mysqld] max_allowed_packet = 20M ``` 4. **保存文件并重启 MySQL 服务** 使用管理员权限运行命令提示符,输入以下命令以重启 MySQL 服务: ```cmd net stop mysql net start mysql ``` 完成上述操作后,可以通过查询确认参数是否生效: ```sql SELECT @@max_allowed_packet; ``` 结果显示应为新设定的值(如 `20971520` 表示 20MB)。[^3] --- #### 方法二:动态调整(无需重启) 也可以不更改配置文件而直接通过 SQL 命令临时修改此参数: 1. 登录 MySQL 数据库: ```bash mysql -u root -p ``` 2. 设置全局变量: ```sql SET GLOBAL max_allowed_packet = 100 * 1024 * 1024; ``` 这里将最大允许数据包大小设为了 100 MB。 注意:这种方式仅对当前会话有效,下次启动 MySQL 后仍恢复默认值。因此建议结合方法一长期固定设置。[^1] --- #### 方法三:验证设置效果 无论采用哪种方式,都可以通过以下 SQL 查询来检验实际生效情况: ```sql SELECT @@global.max_allowed_packet AS global_value, @@session.max_allowed_packet AS session_value; ``` 这能分别查看全局和当前会话级别的 `max_allowed_packet` 值。[^2] --- #### 注意事项 - 修改前请备份原始配置文件以防误改影响正常工作。 - 若涉及大容量导入导出场景,请确保客户端连接也支持相应的大数据传输能力,可能还需同步调整 `[client]` 和 `[mysql]` 配置部分的最大包尺寸限制。[^4] ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值