kakfa+zookeeper集群搭建
1:下载对应安装包
zookeeper-3.4.14.tar.gz:链接:https://pan.baidu.com/s/19_eYsv5r9bg0AKv3TzjpZQ 提取码:ik8a
kafka_2.12-2.1.1.tgz: 链接:https://pan.baidu.com/s/1VcLtB17fEzFrVyvran1qhQ 提取码:e4f1
2:解压对应软件包
mkdir /data tar zxf zookeeper-3.4.14.tar.gz -C /data/ gzip -d kafka_2.12-2.1.1.tgz tar xvf kafka_2.12-2.1.1.tar -C /data/
3:进行相对应的配置
cd /data/zookeeper-3.4.14/conf [root@kafka1 conf]# cat zoo.cfg #心跳间隔时间,zookeeper中使用的基本时间单位,毫秒值。每隔2秒发送一个心跳 tickTime=2000 #leader与客户端连接超时时间。表示10个心跳间隔 initLimit=10 #Leader与Follower之间的超时时间,表示5个心跳间隔 syncLimit=5 dataDir=/data/zookeeper-3.4.14/data/ #数据目录 dataLogDir=/data/zookeeper-3.4.14/data/ #日志目录 clientPort=2181 #客户端连接端口 server.1=10.251.23.162:2888:3888 server.2=10.251.23.163:2888:3888 server.3=10.251.23.164:2888:3888
上述server.{1,2,3} 是zookeeper新增../data/myid配置文件1和kakfa服务内server.properties配置的broker.id和kafkalog/meta.properties 配置文件内的broker.id=1这几个一定要有不然后续启动会报错
启动kafka报错信息如下:
32 [2019-04-03 23:59:20,892] ERROR Fatal error during KafkaServer startup. Prepare to shutdown (kafka.server.KafkaServer) 33 kafka.common.InconsistentBrokerIdException: Configured broker.id 1 doesn't match stored broker.id 0 in meta.properties. If you moved your data, make sure your configured broker.id matches. If you intend to create a new broker, you should remove all data in your data directories (log.dirs). 34 at kafka.server.KafkaServer.getBrokerIdAndOfflineDirs(KafkaServer.scala:686) 35 at kafka.server.KafkaServer.startup(KafkaServer.scala:209) 36 at kafka.server.KafkaServerStartable.startup(KafkaServerStartable.scala:38) 37 at kafka.Kafka$.main(Kafka.scala:75) 38 at kafka.Kafka.main(Kafka.scala) 39 [2019-04-03 23:59:20,899] INFO shutting down (kafka.server.KafkaServer) 40 [2019-04-03 23:59:20,909] INFO [ZooKeeperClient] Closing. (kafka.zookeeper.ZooKeeperClient) 41 [2019-04-03 23:59:20,926] INFO EventThread shut down for session: 0x1000015a06e0000 (org.apache.zookeeper.ClientCnxn) 42 [2019-04-03 23:59:20,929] INFO Session: 0x1000015a06e0000 closed (org.apache.zookeeper.ZooKeeper) 43 [2019-04-03 23:59:20,952] INFO [ZooKeeperClient] Closed. (kafka.zookeeper.ZooKeeperClient) 44 [2019-04-03 23:59:20,971] INFO shut down completed (kafka.server.KafkaServer) 45 [2019-04-03 23:59:20,998] ERROR Exiting Kafka. (kafka.server.KafkaServerStartable) 46 [2019-04-03 23:59:21,034] INFO shutting down (kafka.server.KafkaServer)
4:添加myid文件,每台机器都需要添加,1机器是1,2机器是2,3机器是3
[root@kafka1 conf]# cat /data/zookeeper-3.4.14/data/myid 1
5:分别启动三台zookeeper
[root@kafka1 bin]# pwd /data/zookeeper-3.4.14/bin [root@kafka1 bin]# ./zkServer.sh start
6:查看状态,分为leader和follower,至此zookeeper已安装完成
[root@kafka1 bin]# ./zkServer.sh status ZooKeeper JMX enabled by default Using config: /data/zookeeper-3.4.14/bin/../conf/zoo.cfg Mode: follower
7:三台配置kafka,具体参数含义,百度吧。。。注意broker.id和listeners监听地址
[root@nlp-staging-kafka1 config]# pwd /data/kafka_2.12-2.1.1/config [root@nlp-staging-kafka1 config]# cat server.properties broker.id=1 #当前机器在集群中的唯一标识,和zookeeper的myid性质一样 listeners=PLAINTEXT://10.251.23.162:9092 num.network.threads=3 #这个是borker进行网络处理的线程数 num.io.threads=8 #这个是borker进行I/O处理的线程数 socket.send.buffer.bytes=102400 #发送缓冲区buffer大小,数据不是一下子就发送的,先回存储到缓冲区了到达一定的大小后在发送,能提高性能 socket.receive.buffer.bytes=102400 #kafka接收缓冲区大小,当数据到达一定大小后在序列化到磁盘 socket.request.max.bytes=104857600 #这个参数是向kafka请求消息或者向kafka发送消息的请请求的最大数,这个值不能超过java的堆栈大小 log.dirs=/data/kafkalogs/ #消息存放的目录,这个目录可以配置为“,”逗号分割的表达式,上面的num.io.threads要大于这个目录的个数这个目录,如果配置多个目录,新创建的topic他把消息持久化的地方是,当前以逗号分割的目录中,那个分区数最少就放那一个 num.partitions=16 #默认的分区数,一个topic默认16个分区数?? num.recovery.threads.per.data.dir=1 offsets.topic.replication.factor=1 transaction.state.log.replication.factor=1 transaction.state.log.min.isr=1 log.retention.hours=24 #默认消息的最大持久化时间,24小时 log.retention.bytes=-1 log.segment.bytes=1073741824 log.retention.check.interval.ms=300000 #默认消息的最大持久化时间,300000小时 zookeeper.connect=localhost:2181 zookeeper.connection.timeout.ms=6000 group.initial.rebalance.delay.ms=0 message.max.byte=5242880 log.cleaner.enable=true delete.topic.enable=true replica.fetch.max.bytes=5242880 offsets.topic.replication.factor=3 transaction.state.log.replication.factor=3 transaction.state.log.min.isr=3 zookeeper.connect=10.251.23.162:2181,10.251.23.163:2181,10.251.23.164:2181 #设置zookeeper的连接端口
8:三台都新增一个文件
[root@kafka1 kafkalogs]# pwd /data/kafkalogs [root@kafka1 kafkalogs]# cat meta.properties version=0 broker.id=1
9:三台分别进入kafka的bin目录启动kafka
./kafka-server-start.sh ../config/server.properties &
至此完成
kakfa+zookeeper集群搭建的更多相关文章
- 分布式架构中一致性解决方案——Zookeeper集群搭建
当我们的项目在不知不觉中做大了之后,各种问题就出来了,真jb头疼,比如性能,业务系统的并行计算的一致性协调问题,比如分布式架构的事务问题, 我们需要多台机器共同commit事务,经典的案例当然是银行转 ...
- kafka学习(二)-zookeeper集群搭建
zookeeper概念 ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名 服务等.Zookeeper是h ...
- 分布式协调服务Zookeeper集群搭建
分布式协调服务Zookeeper集群搭建 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.安装jdk环境 1>.操作环境 [root@node101.yinzhengjie ...
- Zookeeper 集群搭建--单机伪分布式集群
一. zk集群,主从节点,心跳机制(选举模式) 二.Zookeeper集群搭建注意点 1.配置数据文件 myid 1/2/3 对应 server.1/2/3 2.通过./zkCli.sh -serve ...
- Zookeeper集群搭建以及python操作zk
一.Zookeeper原理简介 ZooKeeper是一个开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等. Zookeeper设计目 ...
- Kafka学习之(五)搭建kafka集群之Zookeeper集群搭建
Zookeeper是一种在分布式系统中被广泛用来作为:分布式状态管理.分布式协调管理.分布式配置管理.和分布式锁服务的集群.kafka增加和减少服务器都会在Zookeeper节点上触发相应的事件kaf ...
- zookeeper集群搭建及Leader选举算法源码解析
第一章.zookeeper概述 一.zookeeper 简介 zookeeper 是一个开源的分布式应用程序协调服务器,是 Hadoop 的重要组件. zooKeeper 是一个分布式的,开放源码的分 ...
- 【zookeeper】 zookeeper 集群搭建
集群搭建环境: 发行版:CentOS-6.6 64bit 内核:2.6.32-504.el6.x86_64 CPU:intel-i7 3.6G 内存:2G 集群搭建步骤: 1. 确保机器安装了jdk ...
- Zookeeper(二) zookeeper集群搭建 与使用
一.zookeeper集群搭建 鉴于 zookeeper 本身的特点,服务器集群的节点数推荐设置为奇数台.我这里我规划为三台, 为别为 hadoop01,hadoop02,hadoop03 1. ...
随机推荐
- OffSet和Utc
DateTime dtt = System.DateTime.Now ;//utcnow是格林威治的时间,与北京时间-8 strin(dtt); public static string strin( ...
- nginx服务无法停止(Windows)
本人一般停止nginx服务都是通过Windows自带的任务管理器来强制结束nginx进程实现的,如图 2.但是 这次我通过同样的方法来结束nginx服务,发现nginx的进程无法结束 3.首先我要 ...
- String中文字符转码
如何使用String构造方法和String.getBytes()做好中文字符转码 @Test public void test() { String testStr = "中"; ...
- HttpClient工具类的使用
package com.hourui.gmall.util; import org.apache.http.HttpEntity; import org.apache.http.HttpStatus; ...
- dataset中shuffle()、repeat()、batch()用法
import numpy as npimport tensorflow as tfnp.random.seed(0)x = np.random.sample((11,2))# make a datas ...
- AVR单片机教程——定时器中断
本文隶属于AVR单片机教程系列. 中断,是单片机的精华. 中断基础 当一个事件发生时,CPU会停止当前执行的代码,转而处理这个事件,这就是一个中断.触发中断的事件成为中断源,处理事件的函数称为中断 ...
- PowerDesigner配置Oracle数据库反向工程
PowerDesigner配置Oracle数据库反向工程 作者:Jesai 贴吧:软件频道吧 1. 前言: PowerDesigner是Sybase的企业建模和设计解决方案,采用模型驱动方法,将业务与 ...
- Qt Installer Framework翻译(3-2)
添加组件 如果用户在初始安装期间未选择所有可安装组件,则后续也可以使用包管理器从仓库中获取剩余组件进行安装.包管理器是维护工具的一部分,该维护工具在初始安装过程中与应用程序一起被安装.仅当包含组件的仓 ...
- Go Web 编程之 数据库
概述 数据库用来存储数据.只要不是玩具项目,每个项目都需要用到数据库.现在用的最多的还是 MySQL,PostgreSQL的使用也在快速增长中. 在 Web 开发中,数据库也是必须的.本文将介绍如何在 ...
- [题解]CSP2019 Solution - Part A
至于为什么是 \(\text{Part A}\) 而不是 \(\text{Day 1}\) 那是因为 Day1 T3 还没改 (那这六题的 \(\text{solution}\) 就按难度顺序写吧) ...