ookeeper:伪集群安装部署

只有一台linux主机,但却想要搭建一套zookeeper集群的环境。
可以使用伪集群模式来搭建。
伪集群模式本质上就是在一个linux操作系统里面启动多个zookeeper实例。
这些不同的实例使用不同的端口,配置文件以及数据目录。

创建独立的目录

创建三个目录,隔离开3个zookeeper实例的数据文件,配置文件:

[beanlam@localhost ~]$ mkdir zk1[beanlam@localhost ~]$ mkdir zk2[beanlam@localhost ~]$ mkdir zk3

然后,再分别为每个目录创建一个数据目录,用来存放数据以及id文件

[beanlam@localhost ~]$ mkdir zk1/data[beanlam@localhost ~]$ mkdir zk2/data[beanlam@localhost ~]$ mkdir zk3/data

指定id

zookeeper启动的时候,会在它的数据目录下寻找id文件,以便知道它自己在集群中的编号。

[beanlam@localhost ~]$ echo 1 > zk1/data/myid[beanlam@localhost ~]$ echo 2 > zk2/data/myid[beanlam@localhost ~]$ echo 3 > zk3/data/myid

修改配置文件

这3个实例,每个实例都会使用不同的配置文件启动。
配置示例如下:

# The number of milliseconds of each ticktickTime=2000# The number of ticks that the initial# synchronization phase can takeinitLimit=10# The number of ticks that can pass between# sending a request and getting an acknowledgementsyncLimit=5# the directory where the snapshot is stored.# do not use /tmp for storage, /tmp here is just# example sakes.dataDir=/home/beanlam/zk1/data# the port at which the clients will connectclientPort=2181server.1=127.0.0.1:2222:2223server.2=127.0.0.1:3333:3334server.3=127.0.0.1:4444:4445

这是第一个实例的配置,z1.cfg。把这份配置文件放置在zk1/目录下。
同理,第二个和第三个实例的配置分别为z2.cfg和z3.cfg。和第一个实例一样,放在相同的位置。
唯一不同的是,clientPort必须修改一下,z1.cfg为2181,z2.cfg和z3.cfg不能也是2181,必须彼此不同,比如2182或者2183。

配置文件最底下有一个server.n的配置项,这里配置了两个端口,却一种第一个用于集群间实例的通信,第二个用于leader选举。
至于2181,用于监听客户端的连接。

启动和连接

按照以下方式,依次启动3个实例:

[beanlam@localhost ~]$ cd zk1[beanlam@localhost zk1]$ ~/zookeeper-3.4.8/bin/zkServer.sh start-foreground ./z1.cfg

启动第一个和第二个实例的时候会有报错信息,因为其它实例还没启动完全,连接无法建立的原因,可以直接忽略。
启动完3个实例后,会发现其中有一个是leader,另外两个是follower。可观察输出信息。

接下来启动一个客户端去进行连接:

[beanlam@localhost ~]$ ~/zookeeper-3.4.8/bin/zkCli.sh -server 127.0.0.1:2181,127.0.0.1:2182,127.0.0.1:2183

可以看到,客户端连接上了刚才启动的三个实例中的其中一个。

关键字:zookeeper, beanlam, 实例

版权声明

本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部