首页 > Python基础教程 >
-
ZooKeeper的安装及部署教程
一、Zookeeper介绍
•是一个针对大型分布式系统的可靠协调系统;
•提供的功能包括:配置维护、名字服务、分布式同步、组服务等;
•目标就是封装好复杂易出错的关键职务,将简单易用的接口和性能高效、功能稳定的系统提供给用户;
•Zookeeper已经成为Hadoop生态系统中的基础组件。
二、Zookeeper特点
•最终一致性:为客户端展示同一视图,这是Zookeeper最重要的性能;
•可靠性:如果消息被一台服务器接受,那么它将被所有的服务器接受;
•原子性:更新只能成功或失败,没有中间状态;
2.1 Zookeeper的安装
•Zookeeper安装前需要安装好 JDK。配置好环境变量。
•下载:zookeeper-3.4.5-cdh5.7.0.tar.gz
•解压
tar -zxvf zookeeper-3.4.5-cdh5.7.0.tar.gz -C ~/app/
•解压后进入到 zookeeper目录 找到conf目录, 复制配置文件并编辑
1
2
|
cp zoo_sample.cfg zoo.cfg vi zoo.cfg |
•在zoo.cfg中添加如下内容
1
2
|
dataDir=/home/hadoop/app/zookeeper-3.4.5-cdh5.7.0/data dataLogDir=/home/hadoop/app/zookeeper-3.4.5-cdh5.7.0/logs |
•配置完毕后 进入bin目录运行
./zkServer.sh start
•查看运行状态
1
2
3
4
|
./zkServer.sh status JMX enabled by default Using config: /home/hadoop/app/zookeeper-3.4.5-cdh5.7.0/bin/../conf/zoo.cfg Mode: standalone |
•停止运行
1
2
3
|
./zkServer.sh stop Using config: /home/hadoop/app/zookeeper-3.4.5-cdh5.7.0/bin/../conf/zoo.cfg Stopping zookeeper ... STOPPED |
2.2 zoo.cfg配置
•tickTime: 用于计算的时间单位 比如session超时: N*tickTime
•initLimit: 用于集群, 允许从节点连接并同步到master节点的初始化连接时间, 以tickTime的倍数来表示
•syncLimit: 用于集群, master主节点与从节点之间发送消息, 请求和应答时间长度.(心跳机制)
•dataDir: 必须配置
•dataLogDir:日志目录, 如果不配置会和dataDir公用
•clientPort: 连接服务器的端口, 默认2181
2.3 Zookeeper主要目录结构
•bin 主要的一些运行命令
•conf 存放配置文件, 其中需要修改的是zk.cfg
•contrib:附加的一些功能
•dist-maven: mvn编译后的目录
•docs:文档
•lib: 需要依赖的jar包
•recipes:案例demo代码
•src:源码