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