MYSQL max_allowed_packet

问题

因为业务需求,一个表里一个字段需要存在默认图片的base64,这样数据多了,导致单张表的过大
单张表size 过大,导致导入失败

解决:

mysql 命令行模式下

set global max_allowed_packet = 1024*1024*160;

设置单张表的大小为 160 M;

详解:

mysql 命令行模式下:

show VARIABLES like '%max_allowed_packet%';
捕获.PNG

max_allowed_packet : 单张表的最大允许大小为 4 M;
slave_max_allowed_packet:最大允许值 1 G

max_allowed_packet 针对的是一个事务中的一行记录大小,当一行记录超过了限制的大小,将会报错。sql文件中每次insert完进同一张表的所有数据被称为一个数据包(packet),max_allowed_packet就是来限制这个的大小的阈值,大于这个值,mysql的I/O连接会关闭,就会报这个错。

set global max_allowed_packet = 1024*1024*160;

以上指令为:设置packet 的大小
结果如图:


捕获.PNG

经过测试,MySQL 服务重启,packet 大小恢复默认 4M

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容