(1)Zookeeper在linux环境中搭建集群
1.简介
ZooKeeper是Apache软件基金会的一个软件项目,它为大型分布式计算提供开源的分布式配置服务、同步服务和命名注册。
ZooKeeper的架构通过冗余服务实现高可用性。
Zookeeper的设计目标是将那些复杂且容易出错的分布式一致性服务封装起来,构成一个高效可靠的原语集,并以一系列简单易用的接口提供给用户使用。
一个典型的分布式数据一致性的解决方案,分布式应用程序可以基于它实现诸如数据发布/订阅、负载均衡、命名服务、分布式协调/通知、集群管理、Master选举、分布式锁和分布式队列等功能。
2.zookeeper数据结构
zookkeeper提供的名称空间非常类似于标准文件系统,key-value的形式存储。名称key由斜线/分割的一系列路径元素,zookeeper名称空间中的每个节点都是由一个路径标识。
2. 部署ZooKeeper集群
上面简单介绍了ZooKeeper相关概念,下面我们来部署下ZooKeeper集群。
2.1三台linux虚拟机
IP |
master/slave |
192.168.142.129 |
slave |
192.168.142.130 |
master |
192.168.142.131 |
slave |
Java版本:java version "1.8.0_311"。
2.2下载源码包并解压
官网下载地址(这里有坑,官网给了两个安装包,其中“apache-zookeeper-3.7.0.tar.gz ”是源码,我们要下载“apache-zookeeper-3.7.0-bin.tar.gz”这个编译后安装包才对):
可以通过wget命令下载或者手动下载,安装包存储到linux服务器上/home/deng/packages目录,再通过以下命令解压安装包:
cd /home/deng/packages
mkdir /home/deng/zookeeper
tar zxvf apache-zookeeper-3.7.0.tar.gz -C /home/deng/zookeeper
2.3修改环境变量
vi /etc/profile文件,在文件末尾添加以下环境变量配置:
# ZooKeeper环境变量
export ZOOKEEPER_HOME=/home/deng/zookeeper/apache-zookeeper-3.7.0-bin/
export PATH=$PATH:$ZOOKEEPER_HOME/bin
再运行以下命令使环境变量生效:
source /etc/profile
2.4重命名配置文件
初次使用ZooKeeper时,需要将$ZOOKEEPER_HOME/conf目录下的zoo_sample.cfg重命名为zoo.cfg,zoo.cfg:
mv $ZOOKEEPER_HOME/conf/zoo_sample.cfg $ZOOKEEPER_HOME/conf/zoo.cfg
2.5修改配置文件(指定数据和日志存放目录)
先创建数据跟日志文件夹:
mkdir $ZOOKEEPER_HOME/data
mkdir $ZOOKEEPER_HOME/logs
编辑zoo.cfg配置文件:
vi $ZOOKEEPER_HOME/conf/zoo.cfg
修改如下:
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/home/deng/zookeeper/apache-zookeeper-3.7.0-bin/data
dataLogDir=/home/deng/zookeeper/apache-zookeeper-3.7.0-bin/logs
clientPort=2181
因为我们部署是集群,所以多节点需要在配置文件中尾部增加如下内容:
# 集群配置
server.1=192.168.142.129:2888:3888
server.2=192.168.142.130:2888:3888
server.3=192.168.142.131:2888:3888
如图所示:
2.6生成myid文件,用作标明当前机器
在zookeeper数据所在的目录下(/home/deng/zookeeper/apache-zookeeper-3.7.0-bin/data)生成一个文件叫myid,其中写上一个数字表明当前机器是哪一个编号的机器:
#192.168.142.129(slave)
vi $ZOOKEEPER_HOME/data/myid
1
#192.168.142.130(master)
vi $ZOOKEEPER_HOME/data/myid
2
#192.168.142.131(slave)
vi $ZOOKEEPER_HOME/data/myid
3
2.7开启防火墙端口访问
zookeeper服务默认的端口号为2888和3888,所以需要在防火墙开启允许访问:
firewall-cmd --permanent --zone=public --add-port=2888/tcp
firewall-cmd --permanent --zone=public --add-port=3888/tcp
firewall-cmd --reload
2.8启动Zookeeper
#切换目录
cd /home/deng/zookeeper/apache-zookeeper-3.7.0-bin
#启动ZK服务
bin/zkServer.sh start
#停止ZK服务
bin/zkServer.sh stop
#重启ZK服务
bin/zkServer.sh restart
#查看ZK服务状态
bin/zkServer.sh status
可以通过命令查看ZK服务状态:
参考文献:
Zookeeper-QuickStart
(1)Zookeeper在linux环境中搭建集群的更多相关文章
- (4)ElasticSearch在linux环境中搭建集群
1.概述 一个运行中的Elasticsearch实例称为一个节点(node),而集群是由一个或者多个拥有相同cluster.name配置的节点组成,它们共同承担数据和负载的压力.当有节点加入集群中或者 ...
- Linux环境下Hadoop集群搭建
Linux环境下Hadoop集群搭建 前言: 最近来到了武汉大学,在这里开始了我的研究生生涯.昨天通过学长们的耐心培训,了解了Hadoop,Hdfs,Hive,Hbase,MangoDB等等相关的知识 ...
- Linux环境下SolrCloud集群环境搭建关键步骤
Linux环境下SolrCloud集群环境搭建关键步骤. 前提条件:已经完成ZooKeeper集群环境搭建. 一.下载介质 官网下载地址:http://www.apache.org/dyn/close ...
- Linux环境下HDFS集群环境搭建关键步骤
Linux环境下HDFS集群环境搭建关键步骤记录. 介质版本:hadoop-2.7.3.tar.gz 节点数量:3节点. 一.下载安装介质 官网下载地址:http://hadoop.apache.or ...
- Linux+.NetCore+Nginx搭建集群
本篇和大家分享的是Linux+NetCore+Nginx搭建负载集群,对于netcore2.0发布后,我一直在看官网的文档并学习,关注有哪些新增的东西,我,一个从1.0到2.0的跟随者这里只总结一句话 ...
- Linux环境下Redis集群实践
环境:centos 7 一.编译及安装redis源码 源码地址:redis版本发布列表 cd redis-3.2.8 sudo make && make install 二.创建节点 ...
- Linux环境下nginx集群搭建
#确保安装nginx,stream模块默认不安装的,需要手动添加参数:–with-stream, nginx1.9或以上版本 #nginx.conf文件中,添加以下内容(只供参考),这个不能放在htt ...
- ZooKeeper学习第五期--ZooKeeper管理分布式环境中的数据
引言 本节本来是要介绍ZooKeeper的实现原理,但是ZooKeeper的原理比较复杂,它涉及到了paxos算法.Zab协议.通信协议等相关知识,理解起来比较抽象所以还需要借助一些应用场景,来帮我们 ...
- 【Zookeeper系列】ZooKeeper管理分布式环境中的数据(转)
原文地址:https://www.cnblogs.com/sunddenly/p/4092654.html 引言 本节本来是要介绍ZooKeeper的实现原理,但是ZooKeeper的原理比较复杂,它 ...
随机推荐
- 数学相关函数在PHP中的应用简介
对于数学计算来说,最常见的其实还是我们使用各种操作符的操作,比如说 +加.-减 之类的.当然,PHP 中也为我们提供了一些可以方便地进行其他数学运算的操作函数.这些函数都属于 Math 扩展.这个扩展 ...
- ubuntu安装git并配置SSH Key
安装git apt-get install git 配置git的用户名和邮箱: ssh-keygen -trsa -C "youremail@example.com" ssh-ke ...
- 剑指offer计划27(栈与队列困难)---java
1.1.题目1 剑指 Offer 59 - I. 滑动窗口的最大值 1.2.解法 解题思路:(来自作者bigbeats) 相当于维护一个最大队列(队头元素最大,向队尾非严格递减) 在未形成窗口前,先构 ...
- P4983-忘情【wqs二分,斜率优化】
正题 题目链接:https://www.luogu.com.cn/problem/P4983 题目大意 给出长度为\(n\)的序列\(x\),记平均数为\(\bar{x}\),要求将序列分成\(m\) ...
- VUE自学日志02-应用与组件实例
准备好了吗? 我们刚才简单介绍了 Vue 核心最基本的功能--本教程的其余部分将更加详细地涵盖这些功能以及其它高阶功能,所以请务必读完整个教程! 应用 & 组件实例 创建一个应用实例创建一个应 ...
- 寻找最佳路径(ArcPy实现)
一.背景 随着社会经济发展需求,公路的重要性日益提高.在一些交通欠发达的地区,公路建设迫在眉睫.如何根据实际地形情况设计出比较合理的公路规划,是一个值得研究的问题. 二.实验目的: (1)通过练习,熟 ...
- 题解 AVL 树
link Description 给出一个 \(n\) 个点的 AVL 树,求保留 \(k\) 个点使得字典序最小. \(n\le 5\times 10^5\) Solution 因为我很 sb ,所 ...
- 「JOISC 2020 Day2」变态龙之色 题解
题目传送门 注意 同性必定不同色 必有一个同色异性,且不相互不喜欢 Solution 我们发现,我们问题比较大的就是如何确定性别问题.我们可以一个一个加进去,在原来已经确定了的二分图上增加新的性别关系 ...
- js 面向对象 动态添加标签
有点逻辑 上代码 thml布局 点击查看代码 <!DOCTYPE html> <html lang="en"> <head> <meta ...
- Python中is与==区别
1.在Python中,id是什么?id是内存地址,那就有人问了,什么是内存地址呢? 你只要创建一个数据(对象)那么都会在内存中开辟一个空间,将这个数据临时加在到内存中,那么这个空间是有一个唯一标识的, ...