mysqldump导数报错error 2008处理办法

mysqldump导数报错error 2008处理办法

mysqldump导出dump文件时收到MySQL客户端从服务器获取数据时内存耗尽的报错。

🍌报错信息:

bash 复制代码
mysqldump: Out of memory (Needed 2356236304 bytes)
mysqldump: Got error: 2008: MySQL client ran out of memory when retrieving data from server

🐐可能原因:

单次导出的表行数太多,超过了mysql客户端的内存限制(可能是max_allowed_packet参数,默认256M)。

🐯解决办法:

mysqldump命令加上--single-transaction --skip-opt --extended-insert --quick参数。

也可以单独加上--opt参数,但是生产环境不建议,因为会锁表。

如果需要忽略包含特定字符的表,使用多个--ignore-table参数指定。

导出DBNAME库中的所有表,但不包括TABLE_1和TABLE_2:

bash 复制代码
mysqldump -h127.0.0.1 -P3306 -uroot --set-gtid-purged=OFF \
--single-transaction --skip-opt --add-drop-database --extended-insert --quick \
--ignore-table=DBNAME.TABLE_1 --ignore-table=DBNAME.TABLE_2 \
-B DBNAME > dump_DBNAME_`date +%F`.sql

拼接表名清单:

sql 复制代码
select group_concat(concat_ws('.',table_schema,table_name) separator ' --ignore-table=') 
as not_need_table_list
from information_schema.tables
where table_schema = 'DBNAME' and table_name like '%2023%'\G

📖 重要参数含义官方解释:

  • --opt

    This option, enabled by default, is shorthand for the combination of --add-drop-table --add-locks --create-options --disable-keys --extended-insert --lock-tables --quick --set-charset. It gives a fast dump operation and produces a dump file that can be reloaded into a MySQL server quickly.

    Because the --opt option is enabled by default, you only specify its converse, the --skip-opt to turn off several default settings. See the discussion of mysqldump option groups for information about selectively enabling or disabling a subset of the options affected by --opt.

  • --quick

    This option is useful for dumping large tables. It forces mysqldump to retrieve rows for a table from the server a row at a time rather than retrieving the entire row set and buffering it in memory before writing it out.

  • --extended-insert

    Write INSERT statements using multiple-row syntax that includes several VALUES lists. This results in a smaller dump file and speeds up inserts when the file is reloaded.

References

1\] https://dba.stackexchange.com/questions/157649/outofmemory-exception-duing-mysqldump \[2\] https://dev.mysql.com/doc/refman/8.0/en/mysqldump.html#option_mysqldump_opt \[3\] https://mp.weixin.qq.com/s?__biz=MzI2NzM1OTM4OA==\&mid=2247496679\&idx=1\&sn=bc9391542d1b42c64e1d49632c4cf969\&chksm=ea82b614ddf53f0225e2f7249f907f46552283bdb1970d5b340fc94ed9a72638044444542811\&scene=27

相关推荐
剩下了什么28 分钟前
MySQL JSON_SET() 函数
数据库·mysql·json
java搬砖工-苤-初心不变1 小时前
MySQL 主从复制配置完全指南:从原理到实践
数据库·mysql
Doro再努力2 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
Daniel李华2 小时前
echarts使用案例
android·javascript·echarts
WangYaolove13143 小时前
基于python的在线水果销售系统(源码+文档)
python·mysql·django·毕业设计·源码
做人不要太理性3 小时前
CANN Runtime 运行时组件深度解析:任务调度机制、存储管理策略与维测体系构建逻辑
android·运维·魔珐星云
我命由我123453 小时前
Android 广播 - 静态注册与动态注册对广播接收器实例创建的影响
android·java·开发语言·java-ee·android studio·android-studio·android runtime
朗迹 - 张伟4 小时前
Tauri2 导出 Android 详细教程
android
lpruoyu4 小时前
【Android第一行代码学习笔记】Android架构_四大组件_权限_持久化_通知_异步_服务
android·笔记·学习
霖霖总总4 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法