- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对于一个新网站,我们必须连接到 MySQL master-master 设置。这是一个使用 NHibernate 的 .NET 网站,但同样适用于 Java 或任何其他语言。我们选择此设置是因为我们希望站点在数据库出现故障时继续工作。我们不喜欢停工。
也许我完全误解了主-主设置的工作原理(在 MySQL 中),但在我看来,您可以像往常一样连接到数据库,但在幕后,MySQL 会复制数据两个数据库之间。如果你写,它可以去 master 1 或 master 2,你通常不会知道(除了自动增量 id 会返回一个不同的值)。如果 master A 以某种方式出现故障,master B 仍然可以工作,因此不会停机,master A 将被忽略,直到它再次启动,数据被复制,如果一切顺利,master A 将再次回到现场。
如果这是正确的,如果我上面的漫无边际是错误的,请指正我,如果一个主人倒下了,你需要做些什么特别的事情吗?如果我连接到 192.168.1.50(即 master A),如果 master A 出现故障会怎样? MySQL 会以某种方式自动将我连接到 192.168.1.51(master B)以便我的站点继续工作吗?
如果我错了,那么 MySQL 主-主复制是如何工作的呢?我是否必须告诉每个查询应该在哪个主服务器上执行?那是没有意义的,对吧,因为如果 master A 宕机,那么我对 master A 的所有查询仍然会失败,master-master 设置对我一点帮助也没有。
所以基本上,我认为我的问题实际上是:
do I still connect to a single MySQL host (I'm using NHibernate but that doesn't really matter), do I specify a single connectionstring, and will MySQL know that there are two masters, or does my code change in such a way that I need to specify connectionstrings for both masters (how?), do some special magic to balance the queries between the two servers, etcetera.
我还遗漏了什么吗?谢谢!
最佳答案
Maybe I have a complete misunderstanding of how a master-master setup works (in MySQL), but the way I see it, you connect to your database as you'd normally do, but behind the scenes, MySQL replicates the data between the two databases. If you do a write, it can go to either master 1 or master 2, you normally wouldn't know (except that the auto-increment id would return a different value)
这是不正确的。
MySQL 复制的工作原理是将提交的数据(意味着更改的行或实际的 SQL 语句,取决于复制模式)写入复制日志,然后将该日志传送到从属服务器,从属服务器重播它并进行相同的更改.
在多主机复制中,每个节点既是主机又是从机,从循环中的前一台机器接收更新,并将它们转发到下一台机器。每台机器都有一个在发送和接收复制日志时使用的唯一标识符,允许它识别数据何时完成。
这种方法很原始,但是很有效。传统上,后端管理和维护也是一个真正的痛苦。如果可能的话,不要使用多主机来支持其他解决方案。我在生产中使用 multi-master,根据经验可以这样说。
If I connect to 192.168.1.50 (which is master A), what happens if master A goes down? Will MySQL somehow automagically connect me to 192.168.1.51 (master B) so my site will continue to work?
当您连接到多主机循环中的一台机器时,您仅连接到那台机器。如果您需要能够连接到多台机器,如果其中一台出现故障,那么您将需要通过修改代码或中间负载平衡器来手动处理这种情况。
更糟糕的是,当环路中的一台机器确实宕机时,环路就被打破了。假设您有三个 A、B 和 C。循环将是 A => B => C => A。如果 B 出现故障,A 将无法再向 C 传输更新,这意味着 C 将是唯一安全的连接到机器,直到 B 恢复正常并恢复环路。
关于自增,看auto_increment_increment
and auto_increment_offset
,两个服务器变量,使多主复制设置中的自动递增成为可能。在任何情况下,您都不应在未设置这两个变量的情况下在多主机中使用自动递增。
关于mysql - 从代码连接到 MySQL master-master 设置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7877111/
我在 2 个不同的节点中设置了 master-master mysql 复制。假设如果我要再添加一个节点,即 3rd master ,我是否需要在新服务器中拥有与节点 1 和节点 2 中完全相同的数据
我认为我在理解 git 的基本概念方面是正确的。 我已经设置并克隆了一个远程存储库。我还创建了一个服务器端空存储库,并将我的本地存储库链接到它。 我的问题是我不明白: origin/master 与
从概念上讲,Master-Master 复制是如何工作的? 我认为碰撞将是一种需要以某种方式解决的常见事件。 最佳答案 主-主复制(更一般地——多主复制)在概念上的工作原理是假设冲突并不常见,并且只保
众所周知,mysql 是异步复制的。我听说我需要一些额外的插件来做 同步复制。 那么让我们考虑一下异步复制的情况:master 将事件写入其二进制日志,但不知道 master2 是否或何时检索并处理了
我正在寻求有关 MySql Master-Master 配置问题的帮助。 我正在处理由另一名员工设置的服务器配置,该员工现在无法就此事提供任何帮助。这是我第一次体验这样的设置,在做了相当多的研究之后,
尝试使用 HADOOP 运行 HBASE 时出现以下错误HBASE 0.98.xHADOOP 2.4.0 ERROR [main] master.HMasterCommandLine: Mas
停止独立 Spark Master 失败并显示以下消息: $ ./sbin/stop-master.sh no org.apache.spark.deploy.master.Master to sto
我不确定这是否是一个正常的分支场景,但是...... 假设我从 master 创建一个分支,比如分支 C,然后 merge 回其他先前存在的分支,比如分支 A 和 B,回到 master,然后我需要分
我无法推送到我的 git 存储库。 git clone和 git pull工作正常,但 git push不起作用。 我检查了其他答案,如 here尝试了几种方法,例如 git push origin
所以如果我在 master 中做: git checkout -b my-branch 并在那里做几次提交+推送。然后我做: git checkout master git pull 我现在能以某种方
我设置了 2 个 MYSQL 服务器: my.cnf server1: auto_increment_increment = 2 auto_increment_offset = 1 my.cnf se
我想知道一个服务器是否可以同时是slave和master。我们的问题是我们有很多移动单元需要同步到主服务器,但它们只需要主服务器上 100 个表中的 6 个。除了延迟同步和增加数据成本之外,所有额外的
我有主-主 Mysql 复制。每个主控复制其他主控。谁能解释一下为什么该主机上的 log-bin 文件不同? (尺寸差异很小)。谢谢! 最佳答案 嗯。我们决定使用 mysql 5.6 及其功能 - G
我正在努力理解这里的逻辑,如果术语不正确,我深表歉意。 我正在尝试构建一个功能类似于邮件的应用程序,IE: 所有邮箱 > 特定邮箱 > 消息 其中“所有邮箱”和“特定邮箱”占据 Controller
我一直在使用 master 分支进行开发,并希望将其清除为只有发布提交,以及它的用途。如何将所有内容从 master 复制到开发分支,然后重新启动 master? 最佳答案 Create develo
两周前,我创建了一个新分支,我们称它为exp。在此期间,exp 和 master 中都有几次提交。在此期间,exp 尚未更新 master 的更改 现在我想把所有从 exp 到 master 的更改都
我克隆:https://github.com/vy2014/git_lesson.git 然后我做了一些改动,尝试通过命令git push推送到远程服务器,但是错误: Counting objects
有没有好的方法来解释如何在 Git 中解决“![rejected] master -> master (fetch first)'”? 当我使用此命令时 $ git push origin maste
我该怎么办: 1)恢复推送到主(远程)的更改 2)将这些更改移动到单独的分支 3) 稍后将这些更改移回 master 最佳答案 首先做 2),但前提是你真的需要分支。 git branch chang
符号上有什么区别? 在我的一个工作站上,我克隆的 git 存储库显示(master),而另一个工作站则显示(master -> origin) 我还创建了一个新的本地存储库,提交了一个文本文件,提示仍
我是一名优秀的程序员,十分优秀!