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

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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容