搭建zookeeper的分布式环境

zookeeper的存在是为了进行分布式协调服务的

 

1、什么是分布式;

分布式顾名思义,就是把系统分布到多台计算机上,运用多台计算机的资源处理一些逻辑等,比如一个电商的网站后台需要有 用户、订单、商品等这些表,但是这些表都在一台计算机上,就会同时消耗一台计算机的系统资源,要求的计算机系统的配置必须要高,因此要提高并行计算的效率,把多个业务模块拆分在不通的计算机上,运用分布式的技术处理问题。 分布式需要把任务进行分解和进行节点之间的通信,把这些节点进行集群操作,部署在多台服务器上。

 

 

搭建zookeeper的分布式集群环境

 

zookeeper 环境当中包含三种角色: leader、follower、observer

 

 

 

zookeeper集群的搭建(使用了三台机器)

 

192.168.159.129

192.168.159.130

192.168.159.131

首先这三台机器上面都安装了zookeeper

第一步:修改三台zookeeper的 zoo.cfg文件,在最后面加上配置:

server.1=192.168.159.129:2181:3181

server.2=192.168.159.130:2181:3181

server.3=192.168.159.131:2181:3181

规则是 server.id=host:port:port

id的取值范围是: 1~255,用id来标识机器在该集群中的机器序号。2181是zookeeper的端口,3181是leader选举的端口号

 

zoo.cfg文件的配置解析:

tickTime=2000  zookeeper中最小的时间单位长度(ms)

initLimit=10  follower节点启动后与leader节点完成数据同步的时间 10*2000ms

  syncLimit=5 leader节点和follower节点进行心跳检测的最大延时时间 5*2000ms(大于这个时间点表示 follower节点已经不归leader管理了)

  dataDir=/tmp/zookeeper  表示zookeeper服务器存储快照文件的目录

dataLogDir 表示配置 zookeeper事务日志的存储路径,默认指定在dataDir目录下

  clientPort 表示客户端和服务端建立连接的端口号: 2181

 

 

zookeeper中集群的角色:

leader、、follower、observer

 

zookeeper中的一些概念:

zookeeper的数据模型和文件系统类似,每一个节点称之为 znode,是zookeeper中的最小数据单元,每一个znode上都可以保存数据和挂载子节点,从而构成一个层次化的数据结构,如下图所示。

持久化节点:节点创建之后会一直存在zookeeper的服务器上,直到主动删除。

持久化有序节点:每个节点都会为它的以及子节点维护一个顺序。

临时节点:临时节点的生命周期和客户端的会话保持一致,当客户端会话失效,该节点自动清理。

临时有序节点:在临时节点上多了一个有序性的特性。

 

会话:客户端的状态信息:

 

三台机器上都配置好了zoo.cfg之后,需要在 dataDir指定的目录中为每个节点增加一个 myid ,myid对应的值是 server.1=192.168.159.129:2181:3181 里面的 1 ,另外的则需要配置 2 和 3

 

然后使用命令启动三台zookeeper: zkServer.sh start ,

如果三个节点集群成功,那么输入下面的命令则会显示: zkServer.sh status

Mode里面显示了它是leader、follower、还是 observer

 

使用zkCli.sh 这个命令可以连接上zookeeper的客户端:zkCli.sh -server IP:port

zookeeper当中的一些命令:

ls / 列出 zookeeper上的一级主节点

create -s -e path data acl -s 是否有序 -e 是否临时

默认情况下是持久化节点

create /mic 123 创建 mic的节点

ls /mic 列出mic节点下的所有的节点

create -s /mic/mic1 123 创建一个mic节点

get /mic 获取到mic这个节点的信息

set /mic xxx [version] 修改节点 path 对应的 data

delete /mic/mic1 删除 mic节点下的 mic1节点

set /mic 456 2

修改 path对应的 data,数据库里面有一个dataVersion字段去控制当前数据库的数据版本号。

 

stat 信息(表示节点的状态信息,使用get命令可以获取到下面的信息):

cversion:表示的是子节点的版本号(当前节点的子节点发生变化,这个值会增加)

aclVersion:acl  版本号,修改节点权限

dataVersion:当前节点的数据版本号(只要本节点数据发生变化,就会增加)

czxid:节点被创建时候的事务id

mzxid:节点最后一次被更新的事务id

pzxid:当前节点下的子节点最后一次被修改时候的事务ID

ctime:创建时间

mtime:修改时间

ephemeralOwner:创建临时节点的时候,会有一个sessionid,该值存储sessionid(使用 create -e /app aaa这个指令的时候可以看到该值,临时节点的会话)

dataLength:

numChildren:

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值