当前位置:首页 > AI技术 > 正文内容

MySQL 报错Got a packet bigger than max allowed packet 调整配置|Duuu笔记

admin2个月前 (03-31)AI技术49

max_allowed_packet 是 MySQL 服务端和客户端能接收的最大单个数据包大小,影响 SQL 语句、结果集、BLOB、LOAD DATA 等传输;需同时配置服务端(my.cnf 中 [mysqld] 段或 SET GLOBAL)和客户端(命令行/JDBC/驱动参数),单位注意区分(配置文件支持 M,SQL 必须字节整数);推荐起步值 50–100MB,避免盲目设过大引发 OOM 或复制延迟。

max_allowed_packet 是什么,为什么改它

这个配置项控制 MySQL 服务端和客户端能接收的最大单个数据包大小。不是“上传文件大小”,而是 SQL 语句、结果集、BLOB 字段、LOAD DATA 的行数据等在传输过程中打包的上限。超过就直接报错

Got a packet bigger than max_allowed_packet

,连接中断,不给重试机会。

常见触发场景:

INSERT

含超长 JSON 字符串、

UPDATE

批量写入大文本、用

mysqldump

恢复含大 BLOB 的库、ORM 执行带巨量参数的批量插入(比如 1000 行 × 每行 2MB)。

怎么改:服务端 vs 客户端要分开设

MySQL 的

max_allowed_packet

有两套独立值:服务端(

mysqld

进程)和客户端(

mysql

命令行、JDBC、Python 的

pymysql

等)。只改服务端,客户端仍可能因自身限制提前截断;只改客户端,服务端照样拒绝大包。

Action Figure AI

借助Action Figure AI的先进技术,瞬间将照片转化为定制动作人偶。

下载

服务端生效需重启或动态设置:

SET GLOBAL max_allowed_packet = 64*1024*1024;

(64MB),但该值在重启后丢失;持久化必须写进配置文件

/etc/my.cnf

/etc/mysql/mysql.conf.d/mysqld.cnf

[mysqld]

段下:

max_allowed_packet = 64M

客户端也要配:命令行启动加

--max-allowed-packet=64M

;JDBC URL 加

&maxAllowedPacket=67108864

;Python 的

pymysql.connect()

传参

max_allowed_packet=67108864

注意单位:配置文件里支持

64M

,但 SQL 语句里必须是整数字节(如

67108864

),不能写

64*1024*1024

改多大才安全?别盲目拉到 1G

设太大不光浪费内存,还会放大问题:超大包失败时重传成本高、OOM 风险上升、主从复制延迟加剧(尤其 binlog 格式为

STATEMENT

时,一个大包可能对应几万行变更)。

先确认真实需求:用

SELECT LENGTH(blob_col) FROM tbl ORDER BY LENGTH(blob_col) DESC LIMIT 1;

查当前最大单字段长度;用

SHOW VARIABLES LIKE 'max_allowed_packet';

看当前值

推荐起步值:50–100MB。够覆盖绝大多数业务大字段场景,又不至于失控

若用

mysqldump

,记得加

--max-allowed-packet=128M

参数,它的默认值不读全局配置

云数据库(如阿里云 RDS、AWS RDS)通常限制修改该参数,得走控制台申请或选更高规格实例

改完没生效?检查这三处

最常踩的坑不是不会设,而是设了却没起作用——因为生效层级或加载顺序错了。

配置文件路径是否正确?

mysqld --help --verbose | grep "Default options"

能看到实际加载的 cnf 文件列表,优先级从高到低:命令行 >

/etc/my.cnf

>

/etc/mysql/my.cnf

>

$MYSQL_HOME/my.cnf

>

~/.my.cnf

确认改的是

[mysqld]

段,不是

[client]

[mysql]

段(后者只影响客户端工具,不影响服务端接收能力)

动态 SET 后没验证:执行

SHOW VARIABLES LIKE 'max_allowed_packet';

,对比

GLOBAL

SESSION

值;新连接才继承 GLOBAL,旧连接保持原 SESSION 值

服务端配置改完必须重启或

SET GLOBAL

,但客户端连接不重启就不会读新值;很多问题卡在这一步,而不是配置本身写错了。

相关文章

前端开发实战详解:骡子快跑怎么注册账号 骡子快跑账号注册流程最佳实践|Duuu笔记

骡子快跑注册仅需1分钟,但激活码需从Discord指定频道获取,输错3次将锁账户24小时;积分与注册邮箱强绑定且不可更换;部分地区即使注册成功也无法运行Agent。 ☞☞☞AI 智能聊天, 问答助手...

bp神经网络是什么网络,神经网络和bp神经网络

1、前馈神经网络:一种最简单的神经网络,各神经元分层排列。每个神经元只与前一层的神经元相连。接收前一层的输出,并输出给下一层.各层间没有反馈。 2、BP神经网络:是一种按照误差逆向传播...

深入理解AI:WorkBuddy 怎么做组织架构图 WorkBuddy 组织架构图生成教程【实战】完全指南|Duuu笔记

WorkBuddy可通过四种方式生成组织架构图:一、用自然语言指令触发AI自动解析并渲染Mermaid图表;二、上传Excel结构化数据映射字段后批量构建动态树状图;三、启用OpenClaw技能包对接...

AI实战详解:Perplexity 怎么做市场调研 Perplexity 市场分析实操教程【商业】最佳实践|Duuu笔记

掌握Perplexity AI市场调研需五步:一、结构化提问嵌入地域/时间/主体/指标四要素;二、限定PDF等原始信源提升可信度;三、分步提问生成制表符分隔文本以自动导入Excel;四、启用Pro S...

AI高级应用:Perplexity 怎么写用户手册 Perplexity 产品帮助文档生成【技术】实战案例|Duuu笔记

Perplexity AI用户手册需基于API元数据、真实UI截图、典型场景示例、响应字段解析及动态调试指令五步构建:一调用API获取参数与错误码;二标注网页端搜索框、引用图标等组件;三设计信息检索、...

深入理解前端开发:Minimax视频生成黑科技:复杂动作模拟完全指南|Duuu笔记

为精准模拟复杂动作,需采用分帧提示词构建、骨骼关键点引导注入和多阶段动作蒸馏三法:一、将动作拆解为带空间姿态的关键帧序列并加物理约束;二、注入2D/3D关键点坐标锚定关节位置;三、通过粗生成→特征提取...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。