简述:
什么zookeeper?zookeeper是一个分布式的服务注册和发现中心,当服务器端接收到来自客户端的一个服务的时候,通过zookeeper将其注册到注册中心去。那么接下来分别介绍zookeeper的单机搭建和集群搭建:
首先我们要下载zookeeper的安装包:我这里用的是.tar.gz结尾的安装包:
一开始下载的是3.6.0版本的,但是老是启动失败,换了版本成功。
2.通过shell6脚本的rz命令上传到Linux操作系统,如下:
如果我们输入rz命令:不能出现文件夹,通过以下命令安装rz命令:
yum install lrzsz 执行该命令。
-
解压:
tar -zxvf zookeeper-3.4.5.tar.gz 删除安装包:rm -f zookeeper-3.4.5.tar.gz 重命名文件夹:mv zookeeper-3.4.5.tar.gz zookeeper-3.4.5
3.复制到cp zookeeper-3.4.5 /usr/java/zookeeper-3.4.5
切换到:zookeeper-3.4.5/conf/目录下,执行:
cp zoo_sample.cfg zoo.cfg
复制zoo_sample.cfg文件zoo.cfg,因为zookeeper启动时会默认加载zoo.cfg
配置文件。配置文件如下:
tickeTime: zookeeper客户端与zookeeper的心跳时间间隔(毫秒)。
dataDir:用来存放zookeeper内存数据的快照,可以特殊指定,更新到数据库的日志信息
clientport:监听客户端连接的端口。
initLimit:follower服务器与leader服务器,初始连接时,能容忍的最多心跳数
syncLimit:follower服务器和leader服务器,在请求和应答之间能容忍的最多心跳数。
4.进入./bin,执行sh zkServer.sh start 启动zookeeper服务,如下:
启动成功,再查看下zookeeper状态:
单机版的化这里出现的应该是:Mode:standlone,我这个里搭建的时集群所以是follower。选举,一个集群可以有多个follower服务器,但是只能有一个leader(领导)服务器。leader服务器可以处理Leader服务器的提议,他们才参与新leader的选举。
那么我分享下如何搭建集群: 上图显示在zoo.cfg中的集群配置。
server.N=zk_host:port1:port2
N:服务器编号 zk_host:zk的ip地址 port1:zk的通信端口 port2:zk的选举端口。
N服务器编号:必须与myid文件的数字一样,我们可以通过如下命令生成
myid文件:
echo "1">/tmp/zookeeper/myid
设置为以上配置然后我们对三台不同的服务分别启动服务器,查看其状态如下:
以上就是启动服务器成功。接下来进行与客户端的连接:
通过如下命令:
sh zkCli.sh -server 192.168.181.66:2181;192.168.181.67:2181;192.168.181.68:2181
启动成功:
看到以上代码表示与客户端建立连接,以上就是整个集群的搭建讲诉完毕。
ok,我们可以通过idea的dubbo服务连接。