转载至:https://blog.csdn.net/weixin_38111957/article/details/82927878

一、引言

  今天咱们就来搭建一下zookeeper集群,当然搭建集群,只是为了保证更高效的去使用,避免出现单点故障。

二、zookeeper介绍
  zookeeper:看字面的意思是"动物管理员",真正上zookeeper是一个分布式、开源的程序服务器,采用java开发。zookeeper但是不仅仅只能管理solr,比如:hadoop、hive、dubbo等等。zookeeper也是apache提供的开源项目,是hadoop的子项目。

三、集群搭建
  准备条件:linux服务器一台、配置jdk环境、下载zookeeper安装包。

  小编只是为了写教程,采用一台服务器来进行伪分布式搭建,实际上应该是每一台服务器都应该部署一个zookeeper,这样才是真正搭建分布式的意义,一台服务器down掉,其他服务器可以顶替上来。

  wget http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.5.5/apache-zookeeper-3.5.5-bin.tar.gz   #linux上下载zookeeper

步骤一:解压缩zookeeper的安装包

  tar -zxvf apache-zookeeper-3.5.5-bin.tar.gz

  

步骤二:我们在/usr/local/目录下新建一个zookeeper-cluster文件夹,把解压后的zookeeper复制三份到zookeeper-cluster下,分别命名为:zookeeper1、zookeeper2、zookeeper3

mkdir /usr/local/zookeeper-cluster

mv apache-zookeeper-3.5.5-bin.tar.gz /usr/local/solrcloud/zookeeper1 cd /usr/local/zookeeper-cluster/ cp -r zookeeper1/ zookeeper2 cp -r zookeeper1/ zookeeper3

  

步骤三:在每一个zookeeper文件下分别创建一个data文件夹,创建一个myid的文件,并为每一个myid文件写入zookeeper对应的编号。分别是1、2、3,与步骤五的server.1、server.2、server.3 对应

mkdir zookeeper1/data

mkdir zookeeper2/data

mkdir zookeeper3/data

vim zookeeper1/data/myid  #写入内容为 1

vim zookeeper2/data/myid #写入内容为 2

vim zookeeper3/data/myid #写入内容为 3

在每个zookeeper的 data 目录下创建一个 myid 文件,内容分别是1、2、3 。这个文件就是记录每个服务器的ID

步骤四:把每一个zookeeper下中的conf目录下的zoo_sample.cfg,复制一份并改名为zoo.cfg

cp zookeeper1/conf/zoo_sample.cfg zookeeper1/conf/zoo.cfg

cp zookeeper2/conf/zoo_sample.cfg zookeeper2/conf/zoo.cfg

cp zookeeper3/conf/zoo_sample.cfg zookeeper3/conf/zoo.cfg

  

步骤五:修改每一个zookeeper下的conf目录中的zoo.cfg文件,是每个zookeeper下都需要修改噢。

dataDir:配置是刚刚我们所创建的data目录的全路径。

clientPort:配置客户端连接的端口号,zookeeper1=2182、zookeeper=2182、zookeeper3=2183,避免重复

server.1:配置集群中节点的信息,包括ip地址,投票、选举的端口(投票是指:当某一台zookeeper服务器down之后,需要其他zookeeper进行投票来判断是否需要选举新的zookeeper主机,来代替之前down的zookeeper服务)

        

    

解释:server.服务器ID=服务器IP地址:服务器之间通信端口:服务器之间投票选举端口

步骤六:分别启动zookeeper1、2、3,然后分别查看对应的状态。

如下图 Mode是为leader,表示当前zookeeper是工作者,其他为follower,表示从服务器,当leader服务down之后,其他从服务器则会进行投票,代替成为leader

./zookeeper1/bin/zkServer.sh start #启动zookeeper

./zookeeper3/bin/zkServer.sh status # 查看zookeeper状态

./zookeeper3/bin/zkServer.sh stop # 关闭zookeeper

    

    

./zkServer.sh start   #启动zookeeper

./zkServer.sh status  # 查看zookeeper状态
./zkServer.sh stop   # 关闭zookeeper
./zkCli.sh -server localhost:2181   #连接到Zookeeper服务.

linux系统搭建zookeeper集群的更多相关文章

  1. 关于Linux系统下zookeeper集群的搭建

    1.集群概述 1.1什么是集群 1.1.1集群概念 集群是一种计算机系统, 它通过一组松散集成的计算机软件和/或硬件连接起来高度紧密地协作完成计算工作.在某种意义上,他们可以被看作是一台计算机.集群系 ...

  2. Linux下搭建ZooKeeper集群

    摘要 Zookeeper是针对大型分布式系统的高可靠的协调系统.它基于对Paxos算法的实现,使该框架保证了分布式环境中数据的强一致性,也正是基于这样的特性,使得ZooKeeper解决很多分布式问题. ...

  3. Linux系统搭建Hadoop集群

    一.环境说明 IP地址 主机名 备注 操作系统 192.168.92.11 hserver1 namenode Ubuntu 16.04 192.168.92.12 hserver2 datanode ...

  4. Linux环境下ZooKeeper集群环境搭建关键步骤

    ZooKeeper版本:zookeeper-3.4.9 ZooKeeper节点:3个节点 以下为Linux环境下ZooKeeper集群环境搭建关键步骤: 前提条件:已完成在Linux环境中安装JDK并 ...

  5. docker 搭建zookeeper集群和kafka集群

    docker 搭建zookeeper集群 安装docker-compose容器编排工具 Compose介绍 Docker Compose 是 Docker 官方编排(Orchestration)项目之 ...

  6. Linux下搭建tomcat集群全记录(转)

    本文将讲述如何在Linux下搭建tomcat集群,以及搭建过程中可能的遇到的问题和解决方法.为简单起见,本文演示搭建的集群只有两个tomact节点外加一个apache组成,三者将安装在同一机器上:ap ...

  7. 如何搭建Zookeeper集群

     ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是一个为分布式应用提供一致性服务的软件,提供的 ...

  8. Linux下搭建tomcat集群全记录

    (转) Linux下搭建tomcat集群全记录 2011-10-12 10:23 6133人阅读 评论(1) 收藏 举报 tomcatlinuxapacheinterceptorsession集群 1 ...

  9. centos 6.5 搭建zookeeper集群

    为什么使用Zookeeper? 大部分分布式应用需要一个主控.协调器或控制器来管理物理分布的子进程(如资源.任务分配等)目前,大部分应用需要开发私有的协调程序,缺乏一个通用的机制协调程序的反复编写浪费 ...

随机推荐

  1. Redis学习笔记01-分布式锁

    1.分布式锁的定义与理解 在并发任务中,当对数据执行修改和删除时为了防止多个任务同时拿到数据而产生的混乱,这时就要用到分布式锁来限制程序的并发执行. Redis分布式锁本质上要实现的目标就是在Redi ...

  2. [COCI2019] Mobitel

    题目 显然不小于\(n\)这个东西我们不是很好搞,考虑正难则反,求出有多少条路径小于\(n\),之后拿\(C_{n+m}^m\)一减就好了 于是状态为\(dp[i][j][k]\)表示到\((i,j) ...

  3. Mount- Linux必学的60个命令

    1.作用 mount命令的作用是加载文件系统,它的用权限是超级用户或/etc/fstab中允许的使用者. 2.格式 mount -a [-fv] [-t vfstype] [-n] [-rw] [-F ...

  4. C/C++操作SQLite

    最近几天在学习sqlite3,颇有点收获,下面介绍一下简单用法:1.先下载sqlite3.h和sqlite3.c(如果不知道怎么下载的话就去www.sqlite.org)如果要编译成lib.则需要用到 ...

  5. windows修改或删除已保存samba输入的用户名和密码

    可在系统的"控制面板\用户帐户\凭据管理器\windows 凭据"中找到 可以在"开始菜单->运行",输入"control userpasswo ...

  6. Nginx的几个重要模块

    ngx_http_ssl_module 让Nginx可以支持HTTPS的模块,此模块下的大多数指令都应用在http,server上下文 ①ssl on | off; 是否开启ssl功能 ②ssl_ce ...

  7. 最小费用最大流——EK+SPFA

    终于把最小费用最大流学会了啊-- 各种奇奇怪怪的解释我已经看多了,但在某些大佬的指点下,我终于会了. 原来是个好水的东西. 最小费用最大流是什么? 不可能不知道网络流吧?如果不知道,自行百度去-- 费 ...

  8. webpack 处理图片文件

    1. 安装 file-loader html-loader npm install file-loader html-loader --save-dev 其中html-loader生效需配合 html ...

  9. Java内功修炼系列一责任链模式

    在上一节的拦截器中提到,程序的设计者一般会用拦截器替替代动态代理,将动态代理的逻辑隐藏起来,而把拦截器接口提供给开发者,使开发者不需要关系动态代理的具体实现过程,但是有时候需要多个拦截器,而且拦截器之 ...

  10. [code]图像亮度调整enhancement

    //draft 2013.9 //F=X2/u; ////远处细节被淹没. 亮的地方增亮明显,暗的地方更暗. 不可取. // CvScalar rgb; // rgb=cvAvg(src); //fo ...