最近では珍しくもなくなった"Quorum"という言葉。Zookeeper, etcd, Serfといったクラスタ中でデータのレプリケーションを行ってくれるようなツールや、Cassandra, Riakといった分散データベース(NoSQL系)のようなツールにおいても、データの複製に一貫性を持たせる仕組みとしてよく聞かれます。 しかしながら、多くのスライドやWebの記事を読んでも、"Quorum"という語が意味するところは要するに「過半数ノードによる多数決」というような説明が多いように感じていました。 にも関わらず、"Quorum"と呼ばれているのはなぜか?そんな疑問を持っていたので、この機会に調べてみました。 そうしたら、"Quorum"は過半数/多数決という概念を一般化した非常に抽象でパワフルな概念だということがわかりましたのでここにまとめておきたいと思います。 分散システムにおけるデータ
![最近よく聞くQuorumは過半数(多数決)よりも一般的でパワフルな概念だった - Qiita](https://cdn-ak-scissors.b.st-hatena.com/image/square/5ce85e23e45e638ea7ecdfaef9bf90807dc0407a/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9JUU2JTlDJTgwJUU4JUJGJTkxJUUzJTgyJTg4JUUzJTgxJThGJUU4JTgxJTlFJUUzJTgxJThGUXVvcnVtJUUzJTgxJUFGJUU5JTgxJThFJUU1JThEJThBJUU2JTk1JUIwJTI4JUU1JUE0JTlBJUU2JTk1JUIwJUU2JUIxJUJBJTI5JUUzJTgyJTg4JUUzJTgyJThBJUUzJTgyJTgyJUU0JUI4JTgwJUU4JTg4JUFDJUU3JTlBJTg0JUUzJTgxJUE3JUUzJTgzJTkxJUUzJTgzJUFGJUUzJTgzJTk1JUUzJTgzJUFCJUUzJTgxJUFBJUU2JUE2JTgyJUU1JUJGJUI1JUUzJTgxJUEwJUUzJTgxJUEzJUUzJTgxJTlGJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LWNsaXA9ZWxsaXBzaXMmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz1kZGIxODQwY2RlOWEwNDM3YThhNjAzNzE0ZGIxY2RiZg%26mark-x%3D142%26mark-y%3D112%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwZXZlcnBlYWNlJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz1mMzhkNzRjMmUyNWYwZTRkOTBhYjZiMmZkYzEyM2RiMA%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3Dee8d576c912e268b3d40e649d6d39bc7)