首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >主动式/无源拓扑中MySQL InnoDB在原始设备上的应用

主动式/无源拓扑中MySQL InnoDB在原始设备上的应用
EN

Database Administration用户
提问于 2015-10-10 13:43:43
回答 1查看 1.5K关注 0票数 5

我们有一个主动/被动拓扑,其中有两个x86复合体与一个共享原始存储,其中在给定时刻只有一个节点可以访问共享存储(AKA,主动节点)。在主动节点中发生故障转移的情况下,被动节点发起接管并成为具有对共享存储的访问的主动节点。每个节点都有自己的引导设备存储和一个文件系统。但是,共享存储不能在其上安装文件系统。

我们对在两个节点上安装MySQL感兴趣,在这两个节点上,其数据驻留在共享存储中,并且只有活动节点正在运行服务器。

带有MySQL的InnoDB能够在原始设备上运行,还有关于如何运行类似于我们的拓扑结构的集群上的MySQL的指南。但是,在第二个示例中,它们确实在共享存储上安装了一个文件系统。文件系统问题引起了人们的主要关注:

ib_logfile*仍然需要一个文件系统。因此,原始的MySQL特性并不完全是原始的。如果我弄错了,请纠正我。是否有办法将这些文件存储在原始存储中?我们可以将重做日志(ib_logfile0ib_logfile1)保存在节点的引导设备中,并且总是在服务器启动之前删除这些文件(这样,在发生多个故障转移时,我们就不会有旧的日志文件)。然而,这可能导致在事务的中间发生故障时部分提交未提交的事务,从而与事务的整个概念相矛盾。

是否还有更多的文件/特性可能会影响mysql在此拓扑中的行为?

EN

回答 1

Database Administration用户

回答已采纳

发布于 2015-10-14 12:08:38

值得注意的是,InnoDB的预写日志(WAL) ib_logfile*并不是唯一需要文件系统的东西。你有:

  1. mysql模式中可能使用MyISAM存储引擎(每个表的.frm、.MYD、.MYI )的系统表(大多数现在使用5.7版的InnoDB )
  2. 每个.frm表的InnoDB文件,即使在使用共享系统表空间时(所需的表元数据)
  3. MySQL日志文件(错误日志、通用日志、二进制日志)
  4. SSL伪影
  5. auto.cnf (生成并自动存储MySQL实例UUID )
  6. 每个模式的db.opt文件(在/<datadir>/<schema>/中)
  7. 如果您创建一个分区表(在5.7中消失),则为.par文件。
  8. 如果创建触发器,则.trn和.trg文件
  9. InnoDB tmp表空间(5.6+)
  10. 持久缓冲池页映射(ib_buffer_pool,5.6+)

上面的所有内容通常都在数据目录中,所以只要您有datadir=/some/valid/fs/path --这也是在两个节点之间复制(例如DRBD)或共享(例如NFS、GFS、OCFS) --那么您就可以了。

值得注意的是,.frm、.par、.trn、.trg和.opt文件将随新数据字典一起消失。

请继续关注未来几个月的一些重大声明!:)

我不清楚你为什么要用原始设备?不过,我肯定你有自己的理由。:)

祝好运!

票数 3
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/117627

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档