linux下搭建zookeeper集群全流程Centos7.2版本

1.关闭防火墙

[root@master ~]# systemctl stop firewalld[root@master ~]# systemctl disable firewalld

2.关闭selinux## 标题

[root@master ~]# setenforce 0[root@master ~]# vim /etc/selinux/config

设置
SELINUX=disabled
都关闭后必须重启

3.安装jdk和zookeeper

[root@master ~]# mkdir /usr/java[root@master software]# cd /usr/java/[root@master java]# tar -zxvf jdk-8u281-linux-x64.tar.gz[root@master ~]# mkdir /usr/local/software[root@master ~]# cd /usr/local/software/[root@master software]# tar -zxvf apache-zookeeper-3.5.9.tar.gz

4.配置jdk环境变量

[root@slave1 java]# vi /etc/profile#set java environment shift G跳转到最后一行export JAVA_HOME=/usr/java/jdk1.8.0_281export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/libexport PATH=$JAVA_HOME/bin:$PATH

5.环境变量生效

[root@master java]# source /etc/profile 

6.查看jdk版本

[root@master java]# java -version  

7.修改zookeeper配置文件

[root@master conf]# cd /usr/local/software/apache-zookeeper-3.5.9/conf/[root@master conf]# lltotal 12-rw-r--r--. 1 502 games  535 Oct  5 11:01 configuration.xsl-rw-r--r--. 1 502 games 2712 Jan  6 13:56 log4j.properties-rw-r--r--. 1 502 games  922 Jan  6 13:56 zoo_sample.cfg[root@master conf]# cp zoo_sample.cfg zoo.cfg[root@master conf]# vim zoo.cfg

  

上面红色框住的内容即是我们修改的内容:

①、tickTime:基本事件单元,这个时间是作为Zookeeper服务器之间或客户端与服务器之间维持心跳的时间间隔,每隔tickTime时间就会发送一个心跳;最小 的session过期时间为2倍tickTime

②、dataDir:存储内存中数据库快照的位置,除非另有说明,否则指向数据库更新的事务日志。注意:应该谨慎的选择日志存放的位置,使用专用的日志存储设备能够大大提高系统的性能,如果将日志存储在比较繁忙的存储设备上,那么将会很大程度上影像系统性能。

③、client:监听客户端连接的端口。

④、initLimit:允许follower连接并同步到Leader的初始化连接时间,以tickTime为单位。当初始化连接时间超过该值,则表示连接失败。

⑤、syncLimit:表示Leader与Follower之间发送消息时,请求和应答时间长度。如果follower在设置时间内不能与leader通信,那么此follower将会被丢弃。

⑥、server.A=B:C:D

A:其中 A 是一个数字,表示这个是服务器的编号;

B:是这个服务器的 ip 地址;

C:Leader选举的端口;

D:Zookeeper服务器之间的通信端口。
    
我们需要修改的第一个是 dataDir ,在指定的位置处创建好目录。
第二个需要新增的是 server.A=B:C:D 配置,其中 A 对应下面我们即将介绍的myid 文件。B是集群的各个IP地址,C:D 是端口配置。

8.创建myid文件

**在上一步创建的dataDir对应目录创建myid文件 内容为对应的server.X 对应的数字X
3个节点内容分别为1 2 3 **

[root@master data]# vi data/myid[root@master data]# lsmyid[root@master data]# cat myid 0[root@slave1 data]# cat myid 1[root@slave2 data]# cat myid 2

9.配置zookeeper环境变量

[root@ master apache-zookeeper-3.5.9]# vi /etc/profile添加#set zookeeper environmentexport ZK_HOME=/usr/local/software/apache-zookeeper-3.5.9export PATH=$PATH:$ZK_HOME/bin"/etc/profile" 83L, 2041C written#环境变量生效[root@master data]# source /etc/profile

10.启动zookeeper

[root@master data]# zkServer.sh startZooKeeper JMX enabled by defaultUsing config: /usr/local/software/apache-zookeeper-3.5.9/bin/../conf/zoo.cfgStarting zookeeper ... STARTED

启动命令
zkServer.sh start
停止命令
zkServer.sh stop
重启命令
zkServer.sh restart
查看集群节点状态
zkServer.sh status

三台机器,slave1 成功的通过了选举称为了leader(领导者),而剩下的两台成为了 follower(跟随者)。这时候,如果你将slave1关掉,会发现剩下两台又会有一台变成了 leader节点。

11.(番外)配置阿里云yum源

安装阿里云yum源

[root@slave1 yum.repos.d]# cd /etc/yum.repos.d/[root@slave1 yum.repos.d]# wget http://mirrors.aliyun.com/repo/Centos-7.repo

#备份原yum源

[root@slave1 yum.repos.d]# mv CentOS-Base.repo CentOs-Base.repo.bak[root@slave1 yum.repos.d]# mv Centos-7.repo CentOs-Base.repo#清理缓存[root@slave1 yum.repos.d]# yum clean all#重新生成缓存[root@slave1 yum.repos.d]# yum makecache#升级yum源[root@slave1 yum.repos.d]# yum uptade

来源:https://www.icode9.com/content-3-852051.html

(0)

相关推荐