- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的理解是 Zookeeper 经常用于解决分布式系统中“跟踪哪个节点扮演特定角色”的问题(例如,数据库中的主节点或 MapReduce 集群中的主节点等)。
为简单起见,假设我们有一个具有一个主节点和多个副本的数据库,并且数据库中的当前主节点出现故障。在这种情况下,原则上可以将其中一个副本节点设置为新的主节点。此时我的理解是:
如果我们没有 Zookeeper
应用服务器可能不知道我们有一个新的主节点,所以它们会 不是 除非我们在应用服务器本身上有一些自定义逻辑来检测/纠正这个问题,否则知道将写入发送到哪里。
如果我们有 Zookeeper
Zookeeper 会以某种方式 检测 此失败,并更新相应主 key 的值。此外,应用程序服务器可以(可选地?)在 Zookeeper 中注册钩子(Hook),因此 Zookeeper 可以通知它们此故障,以便应用程序服务器可以更新(例如在内存中)哪个 DB 节点是新的主节点。
我的问题是:
最佳答案
1. 和 2. 的答案都称为 leader election process
并通过以下方式简要工作:
当一个进程在 ZK 管理的集群中启动时,集群会进入 election
状态。如果有领导者,则存在已建立的层次结构,并且现有领导者只是经过验证。如果没有领导者(比如 master 宕机),ZK 会强制 znode 使用序列标志来寻找新的领导者。每个节点与其对等节点对话并发送包含节点标识符 (sid) 和它执行的最新事务 (zxid) 的消息。这些消息称为 votes
.当一个节点收到投票时,它可以忽略它,也可以根据 zxid 保留它。如果 zxid 较新,它会保留投票,如果它比它拥有的旧它会丢弃它。如果 zxids 相同,则 sid 最高的投票获胜!所以会有一段时间,所有节点都将拥有相同的投票,这将由 sid 定义新的领导者。这就是 ZK 选举新领导节点的方式!
关于configuration - Zookeeper 如何管理其他集群中的节点角色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62392433/
我正在使用 Ubuntu 16.04。 当我更新时,我收到以下消息 $ sudo apt-get update .... E: dpkg was interrupted, you must manua
似乎有些autoconf项目使用configure.in文件生成configure脚本,有些使用configure.ac。 使用一种或另一种之间的区别/优势是什么? 最佳答案 这只是风格问题。历史上
我正在尝试按如下方式配置 logback,但它抛出了这个错误。配置文件如下: %d{ISO8601} %-5p [%c] %msg%n
从Miguel de Icaza: We use a library profile that is better suited for mobile devices, so we removed f
我有两个 .config 文件,我需要一个 System.Configuration.Configuration那是它们之间的部分合并? 我可以将文件读取为 XML 并轻松创建所需的合并,但它是一个字
我似乎无法理解这两个注释。我尝试阅读 javadocs 但仍然无法弄清楚。任何人都可以用简单的代码来解释这两个吗? 非常感谢。 最佳答案 您使用 @Configuration作为配置 Spring b
我正在为一个简单的问题而焦头烂额。我的 .NET Core 3 应用程序中有一些设置,我认为最好将其移至我的 appsettings.json 文件。我按照本指南这样做:https://www.c-s
我正在为一个简单的问题而焦头烂额。我的 .NET Core 3 应用程序中有一些设置,我认为最好将其移至我的 appsettings.json 文件。我按照本指南这样做:https://www.c-s
我有以下测试方法: [TestMethod] public void TestHarvestMethod() { HarvestTargetTimeRangeUTC time = new Ha
我的以下代码没有产生预期的输出: public static void main(String[] args) throws MalformedURLException { Configura
我知道要从源代码编译和安装某些东西,在 Unix 系统中,涉及的三个步骤是: 1) ./configure 2) make 3) make install 当我检查OpenCV from source
我有以下片段: static void Main(string[] args) { var container = new UnityContainer(); container.Re
我想好像 apache 的 commons-configuration 可能/支持从属性文件中获取属性作为 map 到目前为止,我已经设法使用以下代码片段间接地做到了这一点 Map map = ne
我正在寻找任何技巧来使用 CKEditor 配置中的参数配置我的插件。我必须传递一些只能在显示 View 时传递的参数。 我想要这样的东西(带有 jQuery 适配器的示例): jQuery('t
在我正在玩的代码中,我看到一些地方是 @Configuration 类除了定义静态类之外什么都不做。格式各不相同,但通常是这样的: @Configuration public class someAu
我们在带有 JRE 7 的 Windows 7 中安装了 Cassandra 2.0.6,我们更新了 cassandra.yaml 文件,如下所示: 数据文件目录:D:\cassandra_data\
我在启动类中收到“'Startup.Configuration' 和'Startup.Configuration' 之间的歧义”错误。我不知道我做了什么导致这个问题。我所做的只是创建了一个 DBCon
我已经安装了 Cygwin64,现在我想安装 extundelete . 所以我下载了它,解压了文件,但是当我运行 ./configure 时它说: $ ./configure Configuring
为什么需要做(在容器目录内): # cd /container/directory/ # ./configure 代替: # pwd /external/path # /container/direc
我正在尝试编译qucs-0.0.19但是当我放置./configure时,它给了我以下错误: checking Checking if admsXml is working... no config
我是一名优秀的程序员,十分优秀!