Linux部署Dubbo的注册中心Zookeeper(单机)

目录

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
Linux部署Dubbo的注册中心Zookeeper(单机)_第1张图片

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

  1. initLimit
    这个配置项是用来配置 Zookeeper 接受客户端(这里所说的客户端不是用户连接 Zookeeper 服务器的客户端,而是 Zookeeper 服务器集群中连接到Leader 的 Follower 服务器)初始化连接时最长能忍受多少个心跳时间间隔数。当已经超过 10 个心跳的时间(也就是tickTime)长度后Zookeeper服务器还没有收到客户端的返回信息,那么表明这个客户端连接失败。总的时间长度就是5*2000=10 秒。
  2. syncLimit
    这个配置项标识 Leader 与 Follower 之间发送消息,请求和应答时间长度,最长不能超过多少个 tickTime 的时间长度,总的时间长度就是 2*2000=4秒。
  3. server.A=B:C:D
    其中 A 是一个数字,表示这个是第几号服务器; B 是这个服务器的 IP 地址或/etc/hosts 文件中映射了 IP 的主机名; C 表示的是这个服务器与集群中的 Leader 服务器交换信息的端口; D 表示的是万一集群中的 Leader 服务器挂了,需要一个端口来重新进行选举,选出一个新的 Leader,而这个端口就是用来执行选举时服务器相互通信的端口。如果是伪集群的配置方式,由于 B 都是一样,所以不同的 Zookeeper 实例通信端口号不能一样,所以要给它们分配不同的端口号。
  4. 端口
    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

你可能感兴趣的:(Linux部署Dubbo的注册中心Zookeeper(单机))