centos7.6下kafka_2.12-2.1.1+zookeeper-3.4.13集群部署

1、安装准备

三台服务器:172.20.10.2,172.20.10.3,172.20.10.14

安装包版本:zookeeper-3.4.13   kafka_2.12-2.1.1

java版本:

[root@server1 ~]# java -version
openjdk version "1.8.0_191"
OpenJDK Runtime Environment (build 1.8.0_191-b12)
OpenJDK 64-Bit Server VM (build 25.191-b12, mixed mode)

2、安装zookeeper

下载zookeeper安装包:

[root@server1 download]# wget http://mirrors.shu.edu.cn/apache/zookeeper/zookeeper-3.4.13/zookeeper-3.4.13.tar.gz

解压安装包并移动到/opt目录下:

[root@server1 download]# tar -zvxf zookeeper-3.4.13.tar.gz
[root@server1 download]# mv zookeeper-3.4.13 /opt

将zookeeper-3.4.13/conf/zoo_sample.cfg复制一份并重命名为zoo.cfg:

[root@server1 download]# cp /opt/zookeeper-3.4.13/conf/zoo_sample.cfg /opt/zookeeper-3.4.13/conf/zoo.cfg

修改zoo.cfg中的配置如下:

[root@server1 download]# vi /opt/zookeeper-3.4.13/conf/zoo.cfg
# The number of milliseconds of each tick

tickTime=2000

# The number of ticks that the initial

# synchronization phase can take

initLimit=10

# The number of ticks that can pass between

# sending a request and getting an acknowledgement

syncLimit=5

# the directory where the snapshot is stored.

# do not use /tmp for storage, /tmp here is just

# example sakes.

dataDir=/home/zookeeper/data

dataLogDir=/home/zookeeper/dataLog

server.1=172.20.10.14:2888:3888

server.2=172.20.10.2:2888:3888

server.3=172.20.10.3:2888:3888

# the port at which the clients will connect

clientPort=2181

# the maximum number of client connections.

# increase this if you need to handle more clients

#maxClientCnxns=60

#

# Be sure to read the maintenance section of the

# administrator guide before turning on autopurge.

#

# http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance

#

# The number of snapshots to retain in dataDir

#autopurge.snapRetainCount=3

# Purge task interval in hours

# Set to "0" to disable auto purge feature

#autopurge.purgeInterval=1

说明:

  • dataDir 和 dataLogDir 需要在启动前创建完成
  • clientPort 为 zookeeper的服务端口
  • server.1、server.2 、server.3为zookeeper集群中三个node的信息,定义格式为 hostname:port1:port2,其中 port1 是 node 间通信使用的端口,port2 是node 选举使用的端口,需确保三台主机的这两个端口都是互通的。

分别将三个节点的node编号写入dataDir目录的myid文件

节点一:

[root@server1 download]# echo "1" > /home/zookeeper/data/myid

节点二:

[root@server1 download]# echo "2" > /home/zookeeper/data/myid

节点三:

[root@server1 download]# echo "3" > /home/zookeeper/data/myid

修改log4j的配置文件:

[root@server1 download]# vi /opt/zookeeper-3.4.13/conf/log4j.properties 
# Define some default values that can be overridden by system properties
zookeeper.root.logger=INFO, ROLLINGFILE
zookeeper.console.threshold=INFO
zookeeper.log.dir=/home/zookeeper/logs
zookeeper.log.file=zookeeper.log
zookeeper.log.threshold=DEBUG
zookeeper.tracelog.dir=/home/zookeeper/logs
zookeeper.tracelog.file=zookeeper_trace.log

设置zookeeper环境变量:

[root@server1 download]# vi /etc/profile

在/etc/profile文件最后添加以下内容:

export ZOOKEEPER_HOME=/opt/zookeeper-3.4.13
PATH=${ZOOKEEPER_HOME}/bin:$PATH
export PATH

添加完成后保存退出并使之立即生效:

[root@server1 download]# source /etc/profile

在防火墙中开启zookeeper使用的三个端口:

[root@server1 download]# firewall-cmd --zone=public --add-port=2181/tcp --permanent
[root@server1 download]# firewall-cmd --zone=public --add-port=2888/tcp --permanent
[root@server1 download]# firewall-cmd --zone=public --add-port=3888/tcp --permanent

重新加载防火墙配置:

[root@server1 download]# firewall-cmd --reload

 

在另外两个节点分别配置好zookeeper。

启动并验证zookeeper,分别在三个节点启动zookeeper:

[root@server1 download]# zkServer.sh start

启动完成后查看zookeeper状态,正常情况一个节点的Mode为leader,两个节点的Mode为follower

[root@server1 download]# zkServer.sh status
ZooKeeper JMX enabled by default
Using config: /opt/zookeeper-3.4.13/bin/../conf/zoo.cfg
Mode: follower

3、安装kafka_2.12-2.1.1 

下载安装包:

[root@server1 download]# wget http://mirrors.shu.edu.cn/apache/kafka/2.1.1/kafka_2.12-2.1.1.tgz

解压安装包并移动到/opt目录下:

[root@server1 download]# tar -zvxf kafka_2.12-2.1.1.tgz
[root@server1 download]# mv kafka_2.12-2.1.1 /opt

修改/opt/kafka_2.12-2.1.1/config/server.properties配置文件:

[root@server1 download]# vi /opt/kafka_2.12-2.1.1/config/server.properties

 说明:下面的配置只列出里需要修改的项,没有列出的保持默认值

############################# Server Basics #############################

# The id of the broker. This must be set to a unique integer for each broker.
broker.id=1

############################# Socket Server Settings #############################

# The address the socket server listens on. It will get the value returned from
# java.net.InetAddress.getCanonicalHostName() if not configured.
#   FORMAT:
#     listeners = listener_name://host_name:port
#   EXAMPLE:
#     listeners = PLAINTEXT://your.host.name:9092
listeners=PLAINTEXT://172.20.10.14:9092

# Hostname and port the broker will advertise to producers and consumers. If not set,
# it uses the value for "listeners" if configured.  Otherwise, it will use the value
# returned from java.net.InetAddress.getCanonicalHostName().
advertised.listeners=PLAINTEXT://172.20.10.14:9092

############################# Log Basics #############################

# A comma separated list of directories under which to store log files
log.dirs=/home/kafka/logs

# The default number of log partitions per topic. More partitions allow greater
# parallelism for consumption, but this will also result in more files across
# the brokers.
num.partitions=3

############################# Log Retention Policy #############################


# The minimum age of a log file to be eligible for deletion due to age
#log.retention.hours=168

# A size-based retention policy for logs. Segments are pruned from the log unless the remaining
# segments drop below log.retention.bytes. Functions independently of log.retention.hours.
log.retention.bytes=268435456

############################# Zookeeper #############################

# Zookeeper connection string (see zookeeper docs for details).
# This is a comma separated host:port pairs, each corresponding to a zk
# server. e.g. "127.0.0.1:3000,127.0.0.1:3001,127.0.0.1:3002".
# You can also append an optional chroot string to the urls to specify the
# root directory for all kafka znodes.
zookeeper.connect=172.20.10.14:2181,172.20.10.2:2181,172.20.10.3:2181

创建kafka日志目录

[root@server1 download]# mkdir /home/kafka/logs

设置kafka环境变量

[root@server1 download]# vi /etc/profile

将之前在文最下方添加的内容修改如下:

export ZOOKEEPER_HOME=/opt/zookeeper-3.4.13
export KAFKA_HOME=/opt/kafka_2.12-2.1.1
PATH=${ZOOKEEPER_HOME}/bin:${KAFKA_HOME}/bin:$PATH
export PATH

修改防火墙,开放kafka通信端口:

[root@server1 download]# firewall-cmd --zone=public --add-port=9092/tcp --permanent
[root@server1 download]# firewall-cmd --reload

分别在两外两个节点安装并配置kafka,注意broker.id的值。

分别在三个节点启动kafka:

[root@server1 download]# kafka-server-start.sh -daemon ${KAFKA_HOME}/config/server.properties

创建一个拥有两个分区,两个副本,名为test的topic:

[root@server1 download]# kafka-topics.sh --create --zookeeper 172.20.10.14:2181,172.20.10.2:2181,172.20.10.3:2181 --replication-factor 2 --partitions 2 --topic test
Created topic "test".

查看topic状态:

[root@server1 download]# kafka-topics.sh --describe --zookeeper 172.20.10.14:2181,172.20.10.2:2181,172.20.10.3:2181 --topic test
Topic:test	PartitionCount:2	ReplicationFactor:2	Configs:
	Topic: test	Partition: 0	Leader: 3	Replicas: 3,1	Isr: 3,1
	Topic: test	Partition: 1	Leader: 1	Replicas: 1,2	Isr: 1,2

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值