前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[MYSQL] mysql慢SQL导致mysqldump备份失败 1205

[MYSQL] mysql慢SQL导致mysqldump备份失败 1205

原创
作者头像
大大刺猬
发布2024-09-04 14:40:58
1290
发布2024-09-04 14:40:58
举报
文章被收录于专栏:大大刺猬

导读

mysql备份有时候会报错如下

代码语言:sql
复制
mysqldump: [Warning] Using a password on the command line interface can be insecure.
WARNING: --master-data is deprecated and will be removed in a future version. Use --source-data instead.
mysqldump: Couldn't execute 'FLUSH /*!40101 LOCAL */ TABLES': Lock wait timeout exceeded; try restarting transaction (1205)

分析

这个报错一眼就能看出来是 执行FLUSH /*!40101 LOCAL */ TABLES超时. 也就是一开始就失败了. (简单的锁超时, 问题就结了...)

mysqldump备份过程大致如下

代码语言:sql
复制
SHOW VARIABLES LIKE 'gtid_mode'
FLUSH /*!40101 LOCAL */ TABLES
FLUSH TABLES WITH READ LOCK --master-data才有
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ
START TRANSACTION /*!40100 WITH CONSISTENT SNAPSHOT */
SELECT @@GLOBAL.GTID_EXECUTED
SHOW MASTER STATUS --master-data才有
UNLOCK TABLES
开始备份表......

那么FLUSH TABLES是干嘛的呢?

Closes all open tables, forces all tables in use to be closed, and flushes the prepared statement cache.

This operation requires the FLUSH_TABLES or RELOAD privilege.

For information about prepared statement caching, see Section 10.10.3, “Caching of Prepared Statements and Stored Programs”.

FLUSH TABLES is not permitted when there is an active LOCK TABLES ... READ. To flush and lock tables, use FLUSH TABLES tbl_name ... WITH READ LOCK instead.

就是flush table .....

强制关闭所有打开的表. 这说的啥玩意儿.... 看看对应函数(void mysql_ha_flush(THD *thd))的描述吧.

Flush (close and mark for re-open) all tables that should be should be reopen.

原来还要做一个re-open标记的. 具体的细节我们就不深究了.

多久超时呢?

和参数lock_wait_timeout 有关. 就是普通的锁等待超时. 等待的时候状态是Waiting for table flush (我模拟的时候设置的是120秒. 默认600秒)

总结

  1. 备份通常是在凌晨, 这个时候还有慢sql的情况是不常见的.(查看对应慢日志可以找到对应慢sql, 可以看看执行计划是否使用了索引)
  2. 1205 只有sql执行阶段超长才会遇到, 未提交的事务不会导致这个问题.
  3. 如果无法优化sql/建索引的话, 那就只有修改备份时间或者增大超时时间lock_wait_timeout

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 导读
  • 分析
    • 那么FLUSH TABLES是干嘛的呢?
      • 多久超时呢?
      • 总结
      相关产品与服务
      云数据库 MySQL
      腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档