文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQLump 参数--Lock-Tables浅析

2024-12-03 12:27

关注

本文转载自微信公众号「DBA闲思杂想录」,作者潇湘隐者 。转载本文请联系DBA闲思杂想录公众号。     

mysqldump有一个参数--lock-tables,以前对这个参数也没有深入、详细了解过,直到上次有个网友问“参数lock-tables 是一次性锁定当前库的所有表,还是锁定当前导出表?“ ,之前一直以为只是锁定当前导出表,后面看了参数说明后,

  1. -l, --lock-tables   Lock all tables for read. 
  2.  
  3.                       (Defaults to on; use --skip-lock-tables to disable.) 

自己也不怎么确认了,当时就测试了一下。准备一个稍微大一点的库,如果数据库太小,那么可能mysqldum命令一下子就导出了所有库,很难清晰的看到实验结果。

执行下面命令做逻辑备份

  1. [root@DB-Server ~]# mysqldump -u root -p --default-character-set=utf8  --opt --extended-insert=false --lock-tables MyDB > db_backup_MyDB.sql 
  2.  
  3. Enter password

同时立即执行下面命令

  1. mysql> show open tables where in_use >0; 
  2. +----------+--------------------------------+--------+-------------+ 
  3. Database | Table                          | In_use | Name_locked | 
  4. +----------+--------------------------------+--------+-------------+ 
  5. | MyDB     | AO_60DB71_VERSION              |      1 |           0 | 
  6. | MyDB     | AO_AEFED0_TEAM_TO_MEMBER       |      1 |           0 | 
  7. | MyDB     | AO_4B00E6_STASH_SETTINGS       |      1 |           0 | 
  8. | MyDB     | AO_2D3BEA_FOLIOCF              |      1 |           0 | 
  9. | MyDB     | AO_AEFED0_TEAM_ROLE            |      1 |           0 | 
  10. | MyDB     | AO_60DB71_DETAILVIEWFIELD      |      1 |           0 | 
  11. | MyDB     | AO_60DB71_LEXORANK             |      1 |           0 | 
  12. | MyDB     | AO_6714C7_REPORT_SCHEDULE      |      1 |           0 | 
  13. | MyDB     | AO_E8B6CC_SYNC_AUDIT_LOG       |      1 |           0 | 
  14. | MyDB     | cwd_application                |      1 |           0 | 
  15. | MyDB     | clusternode                    |      1 |           0 | 
  16. | MyDB     | AO_86ED1B_GRACE_PERIOD         |      1 |           0 | 
  17. | MyDB     | AO_60DB71_WORKINGDAYS          |      1 |           0 | 
  18. | MyDB     | cwd_directory                  |      1 |           0 | 
  19. | MyDB     | AO_2D3BEA_BASELINE             |      1 |           0 | 
  20. | MyDB     | fieldlayoutitem                |      1 |           0 | 
  21. | MyDB     | JQUARTZ_BLOB_TRIGGERS          |      1 |           0 | 
  22. | MyDB     | AO_013613_HD_SCHEME_MEMBER     |      1 |           0 | 
  23. | MyDB     | AO_2D3BEA_ALLOCATION           |      1 |           0 | 
  24. | MyDB     | AO_013613_WL_SCHEME            |      1 |           0 | 
  25. | MyDB     | AO_7DEABF_EXEC_CLUSTER_MESSAGE |      1 |           0 | 
  26. .................................................................... 

如上截图,执行mysqldump命令的时候,使用show open tables where in_use >0命令,你会看到MyDB里面的所有表的In_use的值都为1,意味着是当执行mysqldump命令时,是一次性锁定当前库的所有表。而不是锁定当前导出表。

In_use说明

参考资料:

https://dev.mysql.com/doc/refman/5.7/en/show-open-tables.html

https://oracle-base.com/articles/mysql/mysql-identify-locked-tables

 

来源:DBA闲思杂想录内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯