博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Zookeeper之介绍和安装环境准备
阅读量:7152 次
发布时间:2019-06-29

本文共 2889 字,大约阅读时间需要 9 分钟。

hot3.png

zookeeper概述

 ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。   Zookeeper是一个分布式协调服务;就是为用户的分布式应用程序提供协调服务 |序号 |功能 | |--|--| |1 |为别的分布式程序服务的| |2 |本身就是一个分布式程序| |3 |主从协调 服务器节点动态上下线 统一配置管理 分布式共享锁 一名称服务| |4 |管理(存储,读取)用户程序提交的数据 并为用户程序提供数据节点监听服务|

Zookeeper的集群机制

zookeeper是为其他分布式程序提供服务的,所以本身自己不能随便就挂了,所以zookeeper自身的集群机制就很重要。zookeeper的集群机制采用的是半数存活机制,也就是整个集群节点中有半数以上的节点存活,那么整个集群环境可用。这也就是说们的集群节点最好是奇数个节点。

zookeeper集群节点的角色

Leader

Leader服务器是Zookeeper集群工作的核心,其主要工作如下

事务请求的唯一调度和处理者,保证集群事务处理的顺序性。 集群内部各服务器的调度者。

Follower

Follower是Zookeeper集群的跟随者,其主要工作如下

处理客户端非事务性请求(读取数据),转发事务请求给Leader服务器。参与事务请求Proposal的投票。参与Leader选举投票。

集群环境准备

准备3个节点

|ip | 主机名 | |--|--| |192.168.119.20 | zek00| | 192.168.119.21 | zek01 | | 192.168.119.22 | zek02 |

配置ip地址(其他两个如此参上)

删除 HWADDR这行信息 在这里插入图片描述在这里插入图片描述

节点的映射关系

其他两个节点也这样配置 在这里插入图片描述在这里插入图片描述 删除一个文件 在这里插入图片描述 三个节点修改主机名 在这里插入图片描述在这里插入图片描述 重启

配置免密登录

ssh-keygen

四次回车即可 然后四次回车就可以了,然后就可以在当前登录用户的主目录下可以查看到.ssh目录,公钥和私钥就保存在该目录中 在这里插入图片描述

发送公钥给需要免密登录的节点

ssh-copy-id zek00ssh-copy-id zek01ssh-copy-id zek02

在这里插入图片描述 分别发送给各个节点,自身也需要发送。 然后在其他两个节点上重复此步骤

关闭防火墙

重启后生效(永久关闭) 开启: chkconfig iptables on 关闭: chkconfig iptables off

即时生效,重启后失效 开启: service iptables start 关闭: service iptables sto

zookeeper集群搭建

下载地址: linux下载命令

wget http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.4.14/zookeeper-3.4.14.tar.gz

解压缩命令

tar -zxvf zookeeper-3.4.14.tar.gz

配置文件

在这里插入图片描述 修改的地方有两处:

修改zookeeper存储数据的位置添加集群节点信息
# The number of milliseconds of each ticktickTime=2000# The number of ticks that the initial # synchronization phase can takeinitLimit=10# The number of ticks that can pass between # sending a request and getting an acknowledgementsyncLimit=5# the directory where the snapshot is stored.# do not use /tmp for storage, /tmp here is just # example sakes.dataDir=/root/zookeeper/zkdatadataLogDir=/root/zookeeper/zklog# the port at which the clients will connectclientPort=2181# the maximum number of client connections.# increase this if you need to handle more clients#maxClientCnxns=60## Be sure to read the maintenance section of the # administrator guide before turning on autopurge.## http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance## The number of snapshots to retain in dataDir#autopurge.snapRetainCount=3# Purge task interval in hours# Set to "0" to disable auto purge feature#autopurge.purgeInterval=1#zookeeper配置端口server.1=zek00:2888:3888server.2=zek01:2888:3888server.3=zek02:2888:3888

在这里插入图片描述

myid配置

在 zookeeper的数据的存储目录中创建 myid文件,本文既是zkData目录下,这个myid中的内容只有一行信息,即表示我们集群节点的标示,范围在1~255之间。每个节点中的myid的数字和我们在zoo.cfg中的server.数字=host…对应, 创建这块Data目录:

mkdir zkDataecho 3 > zkData/myid

在这里插入图片描述

分发安装文件

将我们hadoop-node01上安装配置的环境分发到hadoop-node02和hadoop-node03两个节点相同的目录下: 在这里插入图片描述 确认分发成功后分别修改zek00和zek01上的myid的值分别为1,2

配置环境变量

在这里插入图片描述在这里插入图片描述 用上面分发文件的方法:(scp 参数 目的地主机名 路径) 发送给其他两个节点,此配置不用在安装根目录下启动

启动

zkServer.sh start

查看状态,分别在每个节点上执行

./bin/zkServer.sh status

zek00 在这里插入图片描述 zek01 在这里插入图片描述 zek02 在这里插入图片描述 说明启动成功

转载于:https://my.oschina.net/u/4116655/blog/3049063

你可能感兴趣的文章
学习javascript并解读JQuery
查看>>
P1120 小木棍 [数据加强版]
查看>>
JS继承之原型继承
查看>>
Excel应该这么玩——2、命名列:消除地址引用
查看>>
Solution for: Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'
查看>>
区间的关系的计数 HDU 4638 离线+树状数组
查看>>
第一个只出现一次的字符
查看>>
Python基础8_文件处理
查看>>
ORA-00054: 资源正忙, 但指定以 NOWAIT 方式获取资源, 或者超时失效
查看>>
结对项目开发(石家庄地铁乘车系统)
查看>>
CentOS6.2安装PhpMyadmin3.3.10
查看>>
Java运行环境的搭建---Windows系统
查看>>
定时任务redis锁+自定义lambda优化提取冗余代码
查看>>
linux每日命令(36):wc命令
查看>>
数论基础(附加例题)
查看>>
web应用,http协议简介,web框架
查看>>
递归找零问题
查看>>
纯手工编写的PE可执行程序
查看>>
实验四
查看>>
go标准库的学习-sync互斥
查看>>