[title]准备工作[/title]
三台Ubuntu虚拟机(ZooKeeper服务器要2n+1的数量)
以下在虚拟机上的操作三台同步进行, 最后三台除了IP不一样, 其他都一样
[title]虚拟机设置固定IP和主机名(可省略, 为了好管理)[/title]
固定IP设置不详细说了, 自行百度, 把三台主机设置到同一个局域网下
IP分别192.168.32.10~12
在每台虚拟机修改hosts设置主机名:
vim /etc/hosts
在下面增加同样的内容:
192.168.32.10 slave-01
192.168.32.11 slave-02
192.168.32.12 slave-03
[title]下载ZooKeeper[/title]
下载地址:http://apache.fayea.com/zookeeper/
目前zookeeper-3.4.9是最新稳定版
[title]解压配置ZooKeeper[/title]
建立目录
mkdir /opt/zookeeper
建立zookeeper数据目录
mkdir /opt/zookeeper/data
建立zookeeper日志目录
mkdir /opt/zookeeper/logs
将下载的zookeeper-3.4.9.tar.gz上传到此目录, 解压
cd /opt/zookeeper
tar -zxvf zookeeper-3.4.9.tar.gz
进入配置文件目录
cd zookeeper-3.4.9/conf
将zoo_sample.cfg更名为zoo.cfg
mv zoo_sample.cfg zoo.cfg
编辑zoo.cfg
vim zoo.cfg
[title]配置文件的说明[/title]
tickTime :基本事件单元,以毫秒为单位。这个时间是作为 Zookeeper 服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个 tickTime 时间就会发送一个心跳。
dataDir :存储内存中数据库快照的位置,顾名思义就是 Zookeeper 保存数据的目录,默认情况下,Zookeeper 将写数据的日志文件也保存在这个目录里。
clientPort :这个端口就是客户端连接 Zookeeper 服务器的端口,Zookeeper 会监听这个端口,接受客户端的访问请求。
initLimit:这个配置项是用来配置 Zookeeper 接受客户端初始化连接时最长能忍受多少个心跳时间间隔数,当已经超过 5 个心跳的时间(也就是 tickTime)长度后 Zookeeper 服务器还没有收到客户端的返回信息,那么表明这个客户端连接失败。总的时间长度就是 5*2000=10 秒。
syncLimit:这个配置项标识 Leader 与 Follower 之间发送消息,请求和应答时间长度,最长不能超过多少个 tickTime 的时间长度,总的时间长度就是 2*2000=4 秒
server.A = B:C:D : A表示这个是第几号服务器,B 是这个服务器的 ip 地址;C 表示的是这个服务器与集群中的 Leader 服务器交换信息的端口;D 表示的是万一集群中的 Leader 服务器挂了,需要一个端口来重新进行选举,选出一个新的 Leader
配置结束把这份配置分别copy到另外两台虚拟机
[title]启动ZooKeeper[/title]
三台主机分别启动
cd /opt/zookeeper/zookeeper-3.4.9/bin
sh zkServer.sh start
Ubuntu会启动出错, 解决办法
看到Starting zookeeper ... STARTED表示启动成功
都启动完之后可以查看各自的状态
sh zkServer.sh status
若显示Error contacting service. It is probably not running,则使用sh zkServer.sh start-foreground 启动。观察错误信息进行解决
可以看到选出的Leader与两个Follower, 至此zk搭建结束, 接下来开始整合spring和dubbo
5.Dubbo+Spring整合
待续
6.简单Provider和Consumer工程
待续
文章评论