本机安装 ZooKeeper 集群

ZooKeeper 的集群最好是使用 3,5,7,9 奇数台服务器,开发环境可能没有这么多机器给我们使用,不过可以在本机运行多个 ZooKeeper 实例,模拟集群。

下载 ZooKeeper

访问 http://zookeeper.apache.org/releases.html#download 下载 ZooKeeper。

  • 安装 ZooKeeper

ZooKeeper 是绿色软件,解压即是安装。解压下载得到的 zookeeper-3.3.6.tar.gz 三次(不要在意版本号),并重命名得到三个目录,每个目录下是一个 ZooKeeper 的实例,例如放在目录 /Users/Biao/Documents/zookeeper 下:

  • /Users/Biao/Documents/zookeeper/zookeeper-1
  • /Users/Biao/Documents/zookeeper/zookeeper-2
  • /Users/Biao/Documents/zookeeper/zookeeper-3
├── zookeeper-1
│   ├── bin
│   ├── conf
│   ├── contrib
├── zookeeper-2
│   ├── bin
│   ├── conf
│   ├── contrib
├── zookeeper-3
│   ├── bin
│   ├── conf
│   ├── contrib

data 和 log 目录

为每个 ZooKeeper 实例创建独立的数据存储目录 data 和日志目录 log,例如放在目录 /Users/Biao/Documents/zookeeper 下:

  • /Users/Biao/Documents/zookeeper/temp/zk1
  • /Users/Biao/Documents/zookeeper/temp/zk2
  • /Users/Biao/Documents/zookeeper/temp/zk3
/Users/Biao/Documents/zookeeper/temp/zk1
├── temp
│   ├── zk1
│   │   ├── data
│   │   └── log
│   ├── zk2
│   │   ├── data
│   │   └── log
│   └── zk3
│       ├── data
│       └── log

zk1 是 ZooKeeper 实例 1 的目录

zk2 是 ZooKeeper 实例 2 的目录

zk3 是 ZooKeeper 实例 3 的目

服务器 ID 文件 myid

  • 创建文件 /Users/Biao/Documents/zookeeper/temp/zk1/data/myid,内容为 1
  • 创建文件 /Users/Biao/Documents/zookeeper/temp/zk2/data/myid,内容为 2
  • 创建文件 /Users/Biao/Documents/zookeeper/temp/zk3/data/myid,内容为 3

配置文件 zoo.cfg

为每个 ZooKeeper 实例创建配置文件,在 ZooKeeper 的 conf 目录中
  • 创建 /Users/Biao/Documents/zookeeper/zookeeper-1/conf/zoo.cfg,内容为:
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/Users/Biao/Documents/zookeeper/temp/zk1/data
dataLogDir=/Users/Biao/Documents/zookeeper/temp/zk1/log
clientPort=2181
server.1=localhost:2287:3387
server.2=localhost:2288:3388
server.3=localhost:2289:3389

clientPort: the port at which the clients will connect,例如下面用到的 zkCli.sh

创建 /Users/Biao/Documents/zookeeper/zookeeper-2/conf/zoo.cfg,内容为:
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/Users/Biao/Documents/zookeeper/temp/zk2/data
dataLogDir=/Users/Biao/Documents/zookeeper/temp/zk2/log
clientPort=2182
server.1=localhost:2287:3387
server.2=localhost:2288:3388
server.3=localhost:2289:3389

创建 /Users/Biao/Documents/zookeeper/zookeeper-3/conf/zoo.cfg,内容为:


tickTime=2000
initLimit=10
syncLimit=5
dataDir=/Users/Biao/Documents/zookeeper/temp/zk3/data
dataLogDir=/Users/Biao/Documents/zookeeper/temp/zk3/log
clientPort=2183
server.1=localhost:2287:3387
server.2=localhost:2288:3388
server.3=localhost:2289:3389

因为是在一台机器上模拟集群,所以每个 ZooKeeper 实例的端口号 clientPort 不同。

生产环境中,分布式集群部署的步骤与上面基本相同,只不过因为各 ZooKeeper 分布在不同的机器,上述配置文件中的 localhost 换成各服务器的真实 IP 即可。分布在不同的机器后,不存在端口冲突问题,可以让每个服务器的 clientPort 均采用相同的端口,这样管理起来比较方便。

启动 ZooKeeper

执行下面的命令启动 ZooKeeper 服务器:
  • /Users/Biao/Documents/zookeeper/zookeeper-1/bin/zkServer.sh start
  • /Users/Biao/Documents/zookeeper/zookeeper-2/bin/zkServer.sh start
  • /Users/Biao/Documents/zookeeper/zookeeper-3/bin/zkServer.sh start
使用命令 jps 可以看到 ZooKeeper 的进程信息
17145 QuorumPeerMain
17212 QuorumPeerMain
17234 QuorumPeerMain

或则从任务管理器里可以看到 3 个名为 java 的进程,看看进程信息就知道是不是 ZooKeeper 的进程了,很多 Java 程序的进程名都叫 java。


访问 ZooKeeper

执行命令 bin/zkCli.sh -server localhost:2181,localhost:2182,127.0.0.1:2183 使用 ZooKeeper 客户端访问 ZooKeeper,连接成功则说明 ZooKeeper 服务启动了:

Connecting to localhost:2181
2017-04-11 21:33:56,163 - INFO  [main:Environment@97] - Client environment:zookeeper.version=3.3.6-1366786, built on 07/29/2012 06:22 GMT
2017-04-11 21:33:56,165 - INFO  [main:Environment@97] - Client environment:host.name=192.168.0.101
2017-04-11 21:33:56,166 - INFO  [main:Environment@97] - Client environment:java.version=1.8.0_77
2017-04-11 21:33:56,166 - INFO  [main:Environment@97] - Client environment:java.vendor=Oracle Corporation

使用客户端访问 ZooKeeper 时传入了 ZooKeeper 集群的多个服务器的 IP:Port 信息,当某一个 ZooKeeper 的进程关闭后客户端会自动连接到其他 ZooKeeper 服务器。所以要连接的 ZooKeeper 集群的服务器信息并不是 ZooKeeper 服务器告诉客户端的,而是我们明确的指定给客户端的。

执行 bin/zkCli.sh 则连接到本机的 2181 端口的 ZooKeeper,当 2181 的 ZooKeeper 进程关闭后,不会自动连接到其他的 ZooKeeper。

至此,本机 ZooKeeper 的集群搭建完成,以后就可以在此基础上使用 ZooKeeper 开发了,例如使用 Dubbo 开发分布式服务。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容

  • ZooKeeper 的集群最好是使用 3,5,7,9 奇数台服务器,开发环境可能没有这么多机器给我们使用,不过可以...
    wanggs阅读 401评论 0 0
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,649评论 18 139
  • 说到分布式开发Zookeeper是必须了解和掌握的,分布式消息服务kafka 、hbase 到hadoop等分布式...
    欢醉阅读 1,534评论 0 7
  • 1 Zookeeper概述# ZooKeeper是一个为分布式应用所设计的分布的、开源的协调服务,它主要是用来解决...
    七寸知架构阅读 7,348评论 0 101
  • 妈妈劳动委员是干什么的?我想当劳动委员。我告诉女儿,和同学们一起搞卫生,把班级整理干干净净
    时凯旋阅读 138评论 0 0