目录
1.0 简单介绍
1.1关于DUBBO
1.2 关于Zookeeper
2.0 Zookeeper单机部署
2.1 选一台服务器为注册中心服务器,安装Zookeeper
1> 修改操作系统的/etc/hosts,添加别名
2> 下载zookeeper安装包
3> 解压zookeeper安装包
2.2 配置Zookeeper
1> 在zookeeper-3.4.9目录中创建data和logs目录
2> 修改zookeeper配置文件
3> 创建myid文件,输入服务器的编号
4> 编辑.bash_profile,增加zookeeper的环境变量
2.3 启动Zookeeper服务
1> 启动zookeeper服务
2> 配置zookeeper开机自动启动
2.4 防火墙配置
1> 编辑防火墙配置文件,添加端口访问规则
2> 查看防火墙的规则
3.0 补充
1> 查看zookeeper进程
2> 查看zookeeper状态
3> 查看zookeeper服务输出的信息
4> 停止zookeeper服务
1.0 简单介绍
1.1 关于DUBBO
DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000+个服务提供3,000,000,000+次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。
1.2 关于Zookeeper
Zookeeper是为分布式应用程序提供高性能协调服务的工具集合,也是Google的Chubby一个开源的实现,是Hadoop的分布式协调服务。它包含一个简单的原语集,分布式应用程序可以基于它实现配置维护、命名服务、分布式同步、组服务等。Zookeeper可以用来保证数据在ZK集群之间的数据的事务性一致。其中ZooKeeper提供通用的分布式锁服务,用以协调分布式应用。
Zookeeper作为Hadoop项目中的一个子项目,是Hadoop集群管理的一个必不可少的模块,它主要用来解决分布式应用中经常遇到的数据管理问题,如集群管理、统一命名服务、分布式配置管理、分布式消息队列、分布式锁、分布式协调等。在Hadoop中,它管理Hadoop集群中的NameNode,还有在Hbase中Master Election、Server 之间状态同状步等。
Zoopkeeper提供了一套很好的分布式集群管理的机制,就是它这种基于层次型的目录树的数据结构,并对树中的节点进行有效管理,从而可以设计出多种多样的分布式的数据管理模型。
DUBBO推荐生产环境中的注册中心使用Zookeeper,支持基于网络的集群方式。
2.0 Zookeeper单机部署
- 环境:CentOS 6.8 x64
- IP:x.x.x.x
- Zookeeper版本:3.4.9
- 系统用户:root
2.1 选一台空服务器为注册中心服务器,安装Zookeeper
1> 修改操作系统的/etc/hosts,添加别名
[root@iZbp ~]# vim /etc/hosts
# Zookeeper Server
121.43.161.35 xxx-provider-01
2> 下载zookeeper安装包
# wget http://apache.fayea.com/zookeeper/zookeeper-3.4.9/zookeeper-3.4.9.tar.gz
3> 解压zookeeper安装包
# tar -zxvf zookeeper-3.4.9.tar.gz
2.2 配置Zookeeper
1> 在zookeeper-3.4.9目录中创建data和logs目录
# cd /data/
# mv ~/zookeeper-3.4.9 ./
# ls
lost+found mysql wwwlogs wwwroot zookeeper-3.4.9
# cd zookeeper-3.4.9/
# mkdir data
# mkdir logs
2> 修改zookeeper配置文件
拷贝/conf/zoo_sample.cfg,命名为zoo.cfg
[root@iZbp zookeeper-3.4.9]# cd conf/
[root@iZbp conf]# ls
configuration.xsl log4j.properties zoo_sample.cfg
[root@iZbp conf]# cp zoo_sample.cfg zoo.cfg
修改zoo.cfg配置文件
# vim zoo.cfg
2 tickTime=2000
5 initLimit=10
8 syncLimit=5
12 dataDir=/data/zookeeper-3.4.9/data
13 dataLogDir=/data/zookeeper-3.4.9/logs
15 clientPort=2181
16 server.1=xxx-provider-01:2888:3888
TIPS
- initLimit
这个配置项是用来配置 Zookeeper 接受客户端(这里所说的客户端不是用户连接 Zookeeper 服务器的客户端,而是 Zookeeper 服务器集群中连接到Leader 的 Follower 服务器)初始化连接时最长能忍受多少个心跳时间间隔数。当已经超过 10 个心跳的时间(也就是tickTime)长度后Zookeeper服务器还没有收到客户端的返回信息,那么表明这个客户端连接失败。总的时间长度就是5*2000=10 秒。 - syncLimit
这个配置项标识 Leader 与 Follower 之间发送消息,请求和应答时间长度,最长不能超过多少个 tickTime 的时间长度,总的时间长度就是 2*2000=4秒。 - server.A=B:C:D
其中 A 是一个数字,表示这个是第几号服务器; B 是这个服务器的 IP 地址或/etc/hosts 文件中映射了 IP 的主机名; C 表示的是这个服务器与集群中的 Leader 服务器交换信息的端口; D 表示的是万一集群中的 Leader 服务器挂了,需要一个端口来重新进行选举,选出一个新的 Leader,而这个端口就是用来执行选举时服务器相互通信的端口。如果是伪集群的配置方式,由于 B 都是一样,所以不同的 Zookeeper 实例通信端口号不能一样,所以要给它们分配不同的端口号。 - 端口
2888 端口号是 zookeeper 服务之间通信的端口。
3888 是 zookeeper 与其他应用程序通信的端口。
ddxstore-provider-01 是在 hosts 中已映射了 IP 的主机名
3> 创建myid文件,输入服务器的编号
[root@iZbp conf]# cd /data/zookeeper-3.4.9/data/
[root@iZbp data]# vim myid
1
因为只在一台服务器上安装配置,是个单点server.1,因此填1;
4> 编辑.bash_profile,增加zookeeper的环境变量
[root@iZbp data]# cd ~
[root@iZbp ~]# vim .bash_profile
# Zookeeper
export ZOOKEEPER_HOME=/data/zookeeper-3.4.9
export PATH=$ZOOKEEPER_HOME/bin:$PATH
[root@iZbp ~]# source .bash_profile
2.3 启动Zookeeper服务
1> 启动zookeeper服务
[root@iZbp ~]# cd /data/zookeeper-3.4.9/bin/
[root@iZbp bin]# zkServer.sh start
ZooKeeper JMX enabled by default
Using config: /data/zookeeper-3.4.9/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED
2> 配置zookeeper开机自动启动
[root@iZbp bin]# vim /etc/rc.local
#执行Zookeeper启动命令
/data/zookeeper-3.4.9/bin/zkServer.sh start
2.4 防火墙配置
1> 编辑防火墙配置文件,添加端口访问规则
[root@iZbp ~]# vim /etc/sysconfig/iptables
# Zookeeper
-A INPUT -m state --state NEW -m tcp -p tcp --dport 2181 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 2888 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3888 -j ACCEPT
[root@iZbp ~]# chkconfig iptables on
[root@iZbp ~]# service iptables restart
iptables: Setting chains to policy ACCEPT: filter [ OK ]
iptables: Flushing firewall rules: [ OK ]
iptables: Unloading modules: [ OK ]
iptables: Applying firewall rules: [ OK ]
2> 查看防火墙的规则
[root@iZbp ~]# service iptables status
Table: filter
Chain INPUT (policy ACCEPT)
num target prot opt source destination
1 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:88
2 ACCEPT all -- 0.0.0.0/0 0.0.0.0/0 state RELATED,ESTABLISHED
3 ACCEPT icmp -- 0.0.0.0/0 0.0.0.0/0
4 ACCEPT all -- 0.0.0.0/0 0.0.0.0/0
5 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 state NEW tcp dpt:21
6 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 state NEW tcp dpt:22
7 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 state NEW tcp dpt:80
8 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 state NEW tcp dpt:3306
9 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 state NEW tcp dpt:2181
10 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 state NEW tcp dpt:2888
11 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 state NEW tcp dpt:3888
Chain FORWARD (policy ACCEPT)
num target prot opt source destination
Chain OUTPUT (policy ACCEPT)
num target prot opt source destination
到这里,Linux环境下Dubbo的注册中心Zookeeper单机版已经部署完成了!
命令行测试
Windows Platform:
C:\Users\DevOps>telnet x.x.x.x 2181
Linux Platform:
# telnet 127.0.0.1 2181
3.0 补充:
1> 查看zookeeper进程
[root@iZbp bin]# jps
3376 Bootstrap
12737 QuorumPeerMain
1042 jenkins.war
12787 Jps
QuorumPeerMain是zookeeper进程,如果存在,表示启动正常
2> 查看zookeeper状态
[root@iZbp bin]# zkServer.sh status
ZooKeeper JMX enabled by default
Using config: /data/zookeeper-3.4.9/bin/../conf/zoo.cfg
Mode: standalone
3> 查看zookeeper服务输出的信息
[root@iZbp bin]# tail -500f zookeeper.out
4> 停止zookeeper服务
[root@iZbp11rfoyeescusr9ha9qZ bin]# zkServer.sh stop