AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 20602
Accepted
Magnetic_dud
Magnetic_dud
Asked: 2009-06-06 08:04:24 +0800 CST2009-06-06 08:04:24 +0800 CST 2009-06-06 08:04:24 +0800 CST

一致的数据集是什么意思?(MySQL)

  • 772

我每天使用 mysqldump+scheduled 任务对我的 mysql 数据库进行备份

但是,正如我在这个答案中看到的那样,mysqldump 不能保证数据集的一致性……这是什么意思?这意味着如果有人在我备份时访问该网站,并且他的操作将编辑两个表,并且一个表已经被 mysqldump 解析,导致可能导致问题的“不完整”备份?如果mysqldump不好,最好的备份方法是什么?

backup mysql dump
  • 4 4 个回答
  • 1148 Views

4 个回答

  • Voted
  1. David Pashley
    2009-06-06T08:22:43+08:002009-06-06T08:22:43+08:00

    想象两张桌子。当您备份第一个时,第二个会更改。备份将包括该更改。你没有快照。如果说您删除了外键,这是一个问题。

    解决方案是复制一个从数据库,当您进行备份时,您停止复制,进行备份,然后再次开始复制。这样,您就可以及时获得数据库的快照。

    • 4
  2. Best Answer
    Dan Carley
    2009-06-06T08:21:29+08:002009-06-06T08:21:29+08:00

    您可能会导致备份不一致的情况是完全正确的。

    您可以通过添加标志 --lock-all-tables 来使用 mysqldump 进行一致备份。顾名思义,需要注意的是,在备份完成之前,所有表都将被锁定以防写入。这取决于您的数据库的大小可能会很长时间并造成很大的破坏。

    有一些替代方案。其中一些是商业的。我将假设您使用的是 MyISAM,它通常比 InnoDB 更难以一致地备份。

    一种解决方案是将 MySQL 的数据放在存储上,以便通过另一种方法进行更快的备份。例如支持快照的 SAN 或 LVM2 块设备。您仍然必须将 MySQL 置于锁定状态,但由于快照只需很短的时间即可完成,因此破坏性影响可以忽略不计。然后,您可以针对数据快照启动另一个 MySQL 守护程序,以获取一致的 mysqldump 并在闲暇时将其导出到其他地方。

    我自己对 iSCSI 支持的存储使用了类似的方法。

    • 2
  3. James F
    2009-06-07T10:45:06+08:002009-06-07T10:45:06+08:00

    如果您使用 InnoDB 表,有一个名为“热备份”的​​商业工具,可以在服务器启动时创建一致的备份。我不会链接它,因为它是一个商业网站,但如果你有兴趣,谷歌搜索应该会显示它。

    使用其他表格式,你可以获取表的读锁,然后复制底层数据文件,但这会阻塞对表的写操作,所以当应用程序不依赖写或有应用程序时你必须这样做被写入优雅地处理失败的写入。

    MySQL 文档中的更多信息:

    http://dev.mysql.com/doc/refman/5.7/en/replication-solutions-backups-rawdata.html

    • 0
  4. MarkR
    2009-06-07T12:55:33+08:002009-06-07T12:55:33+08:00

    mysqldump 通常会创建一致的快照(除非您告诉它不要这样做)。它通过使用全局读锁锁定整个服务器来实现这一点,这在大多数情况下是不可取的。

    如果您专门使用 InnoDB 表,则可以使用事务转储,它也是一致的,但不会锁定任何内容(长时间)。

    • 0

相关问题

  • Exchange 2007 的备份解决方案

  • IIS 6.0 (Windows Server 2003) 备份的最佳实践?

  • 10TB数据和3台服务器的备份解决方案

  • 最佳混合环境(OS X + Windows)备份?[关闭]

  • 如何从 SQL Server 2008 中的备份中排除索引

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve