Zookeeper搭建集群及协同
Zookeeper搭建集群及协同
协同的实现
首先启动一个zkCli客户端(zkCLi-1),创建一个workers节点。
create /workers
使用ls监控当前节点。
ls -w /workers
[]
当前/workers中没有子节点。
新开一个zkCli客户端(zkCli-2),在/workers中创建一个新节点。
create -e /workers/w1 "w1:2220"
此时zkCli-1中收到通知。
WATCHER::
WatchedEvent state:SyncConnected type:NodeChildrenChanged path:/workers
使用ls在zkCli-1中查看节点信息。
ls -w /workers
返回
[w1]
此时在zkCli-2中执行quit退出。
zkCli-1中再次用ls查看。
[]
这样一个简单的协同服务就已经实现了。
集群搭建
在我们上一篇说的什么是挖矿?一文中,最后留下了一个问题,DPoS算法,这个类似于选举的算法。
Zookeeper集群中,也是使用了一种类似的选举算法,感兴趣的可以去了解一下Paxos算法的论文。
http://lamport.azurewebsites.net/pubs/paxos-simple.pdf
在Zookeeper集群中被选举出来的节点叫做leader,其他节点叫做follow。
为了方便演示,我将我本地的Zookeeper拷贝为了三份,不过记得修改它们三份中的配置文件。
需要修改的是dataDir的路径以及端口号。
服务器0中zoo.cfg
//修改部分
dataDir=/tmp/zookeeper/data0
clientPort=2190
//新增部分(三份cfg均相同)
server.0=127.0.0.1:3333:3334
server.1=127.0.0.1:4444:4445
server.2=127.0.0.1:5555:5556
服务器1中zoo.cfg
//修改部分
dataDir=/tmp/zookeeper/data1
clientPort=2191
//新增部分(三份cfg均相同)
server.0=127.0.0.1:3333:3334
server.1=127.0.0.1:4444:4445
server.2=127.0.0.1:5555:5556
服务器2中zoo.cfg
//修改部分
dataDir=/tmp/zookeeper/data2
clientPort=2192
//新增部分(三份cfg均相同)
server.0=127.0.0.1:3333:3334
server.1=127.0.0.1:4444:4445
server.2=127.0.0.1:5555:5556
分别启动三个Zookeeper服务端。

可以看到已经自动选出了一个Leader节点。
此时我们启动一个zkCli来使用这个三节点集群。
./zkCli.sh -server 127.0.0.1:2190,127.0.0.1:2191,127.0.0.1:2192

可以看到zkCli已经连接到port为2191的节点,也就是服务器1(一个Follower节点)。
现在我们关闭服务器1。

Zookeeper搭建集群及协同的更多相关文章
- ZooKeeper搭建集群
ZooKeeper ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是一个为分布式应用提供一致性 ...
- Zookeeper分布式集群搭建
实验条件:3台安装linux的机子,配置好Java环境. 步骤1:下载并分别解包到每台机子的/home/iHge2k目录下,附上下载地址:http://mirrors.cnnic.cn/apache/ ...
- 初始zookeeper与集群搭建实例
zookeeper是什么 Zookeeper,一种分布式应用的协作服务,是Google的Chubby一个开源的实现,是Hadoop的分布式协调服务,它包含一个简单的原语集,应用于分布式应用的协作服务, ...
- 虚拟机搭建Zookeeper服务器集群完整笔记
虚拟机搭建Zookeeper服务器集群完整笔记 本笔记主要记录自己搭建Zookeeper服务器的全过程,默认已经安装部署好Centos7. 一.虚拟机下Centos无法联网解决方案 1.首先调整虚拟机 ...
- window环境搭建zookeeper,kafka集群
为了演示集群的效果,这里准备一台虚拟机(window 7),在虚拟机中搭建了单IP多节点的zookeeper集群(多IP节点的也是同理的),并且在本机(win 7)和虚拟机中都安装了kafka. 前期 ...
- 搭建zookeeper+kafka集群
搭建zookeeper+kafka集群 一.环境及准备 集群环境: 软件版本: 部署前操作: 关闭防火墙,关闭selinux(生产环境按需关闭或打开) 同步服务器时间,选择公网ntpd服务器或 ...
- win10环境下搭建zookeeper伪集群
一.下载zookeeper https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/ 这里笔者下载的是zookeeper-3.3.6 二.配置zoo ...
- 初识ZooKeeper与集群搭建实例
原文链接:http://www.linuxidc.com/Linux/2015-02/114230.htm zookeeper是什么 Zookeeper,一种分布式应用的协作服务,是Google的Ch ...
- Zookeeper+ActiveMQ集群搭建
搭建三台虚拟机安装centos7.要提前安装好jdk环境 1.环境准备,搭建三台虚拟机ip分别是 192.168.192.130 192.168.192.131 192.168.192.134 Zoo ...
随机推荐
- CocoaPods安装和使用201712
CocoaPods安装使用详解 2017.12 首先,很有必要了解一下CocoaPods.Ruby和RubyGems,以及它们之间的关系. CocoaPods是第三方库的辅助管理工具,依赖于Ruby. ...
- Windows相关操作(备忘)
查看服务端口是否能通:telnet 192.168.1.11 8888 查看端口是否被占用 netstat -ano
- Python 基础语法-str
字符串常见操作 find:检测str是否包含在 mystr 中,如果是返回开始的索引值,否则返回 -1 mystr.index(str, start=0, end=len(mystr)) count: ...
- 44-创建 Machine
对于 Docker Machine 来说,术语 Machine 就是运行 docker daemon 的主机.“创建 Machine” 指的就是在 host 上安装和部署 docker.先执行 doc ...
- 实训第六天(mybatis)
今天实训第六天,我们学习了mybatis这个数据库框架,虽然说框架的环境搭建非常的繁琐,但是在了解原理和流程之后是非常的舒服的.因为有一个强大的工具被我掌握了,所以今天感觉非常的开心. 首先我们是在s ...
- springboot模板
1.thymeleaf模板 2.Freemarker模板 Thymeleaf模板 首先导入依赖 <dependency> <groupId>org.springframewor ...
- GUI程序分析实例
GUI程序开发概述 GUI程序开发原理 GetMessage(&msg)将消息队列中的消息取出来,在循环中进行处理. GUI程序开发的本质
- Httpclient4.5.*HttpClient请求,对于新建httpclient实例时保持会话
package net.bill99.httpconsel; import java.io.IOException; import java.util.*; import java.util.Map. ...
- java之关键字static
static简单概述 static 关键字的基本使用,它可以用来修饰的成员变量和成员方法,一旦用了static关键字修饰,那么这样的内容不再属于对象而是属于类,凡是本类的对象都共享使用同一份.我们可以 ...
- C#关于MySQL中文乱码问题
本人在写一个测试demo的时候,遇到一个问题就是添加的中文数据在数据库定义的明明是varchar类型,但是显示出来还是乱码,不过还是自己粗心导致的问题. 以下三种方式可以自查一下: 1. 首先检查 ...