Kafka集群搭建实战

集群结构:


集群环境信息:

192.168.157.130
192.168.157.131
192.168.157.129

Zookeeper集群搭建

  1. 三台机器上均安装JDK(这里采用压缩包的安装方式jdk-8u301-linux-x64.tar.gz

    xxx:~#tar -zxvf jdk-8u301-linux-x64.tar.gz # 解压文件
    xxx:~#mv jdk1.8.0_301 /opt                 # 移动文件至 /opt目录下
    xxx:~#vim /etc/profile                     # 编辑 /etc/profile 文件
    # jdk
    export JAVA_HOME=/opt/jdk1.8.0_301
    export JRE_HOME=${JAVA_HOME}/jre
    export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
    export PATH=.:${JAVA_HOME}/bin:$PATH
    xxx:~#source /etc/profile                   # 用source命令使新加的配置生效
    xxx:~#java -version                         # java -version 验证java是否配置成功
    java version "1.8.0_301"
    Java(TM) SE Runtime Environment (build 1.8.0_301-b09)
    Java HotSpot(TM) 64-Bit Server VM (build 25.301-b09, mixed mode)
    
  2. 三台机器上均安装Zookeeper用来搭建集群(这里采用压缩包的安装方式zookeeper-3.4.14.tar.gz

    • 第一台机器上配置

      xxx:~#tar -zxf zookeeper-3.4.14.tar.gz      # 解压文件
      xxx:~#mv zookeeper-3.4.14 /opt              # 移动文件至 /opt 目录下
      xxx:~#cd /opt/zookeeper-3.4.14/conf         # 切换目录至 /opt/zookeeper-3.4.14/conf
      xxx:/opt/zookeeper-3.4.14/conf#cp zoo_sample.cfg zoo.cfg # 复制 zoo_sample.cfg 配置文件为 zoo.cfg
      xxx:/opt/zookeeper-3.4.14/conf#vim zoo.cfg  # 编辑 zoo.cfg
      # 设置
      dataDir=/var/software/zookeeper/data
      # 添加
      server.1=192.168.157.130:2881:3881
      server.2=192.168.157.131:2881:3881
      server.3=192.168.157.129:2881:3881
      xxx:/opt/zookeeper-3.4.14/conf#mkdir -p /var/software/zookeeper/data # 创建目录/var/software/zookeeper/data
      xxx:/opt/zookeeper-3.4.14/conf#echo 1 > /var/software/zookeeper/data/myid # 写入 1 至 文件
      xxx:~#vim /etc/profile                      # 编辑 /etc/profile 文件
      # zookeeper
      export ZOOKEEPER_PREFIX=/opt/zookeeper-3.4.14
      export PATH=$PATH:$ZOOKEEPER_PREFIX/bin
      export ZOO_LOG_DIR=/var/software/zookeeper/log
      xxx:~#source /etc/profile                   # 用 source 命令使配置生效
      xxx:~#scp -r /opt/zookeeper-3.4.14/ 192.168.157.131:/opt # 用 scp 命令远程传输文件至指定主机下的指定目录
      xxx:~#scp -r /opt/zookeeper-3.4.14/ 192.168.157.129:/opt # 同上
      
    • 第二台机器上配置

      xxx:~#vim /etc/profile
      # zookeeper
      export ZOOKEEPER_PREFIX=/opt/zookeeper-3.4.14
      export PATH=$PATH:$ZOOKEEPER_PREFIX/bin
      export ZOO_LOG_DIR=/var/software/zookeeper/log
      xxx:~#source /etc/profile
      xxx:~#mkdir -p /var/software/zookeeper/data
      xxx:~#echo 2 > /var/software/zookeeper/data/myid
      
    • 第三台机器上配置

      xxx:~#vim /etc/profile
      # zookeeper
      export ZOOKEEPER_PREFIX=/opt/zookeeper-3.4.14
      export PATH=$PATH:$ZOOKEEPER_PREFIX/bin
      export ZOO_LOG_DIR=/var/software/zookeeper/log
      xxx:~#source /etc/profile
      xxx:~#mkdir -p /var/software/zookeeper/data
      xxx:~#echo 3 > /var/software/zookeeper/data/myid
      
    • 启动zookeeper(三台机器均按如下操作)

      xxx:~#zkServer.sh start
      xxx:~#zkServer.sh status
      

Kafka集群搭建

  1. 三台机器上安装Kafka

    • 第一台机器上配置

      xxx:~#tar -zvxf kafka_2.12-1.0.2.tgz
      xxx:~#mv kafka_2.12-1.0.2 /opt
      xxx:~#scp -r /opt/kafka_2.12-1.0.2/ 192.168.157.131:/opt
      xxx:~#scp -r /opt/kafka_2.12-1.0.2/ 192.168.157.129:/opt
      xxx:~#vim /etc/profile
      # kafka
      export KAFKA_HOME=/opt/kafka_2.12-1.0.2
      export PATH=$PATH:$KAFKA_HOME/bin
      xxx:~#source /etc/profile
      xxx:~#vim /opt/kafka_2.12-1.0.2/config/server.properties
      broker.id=0
      listeners=PLAINTEXT://:9092
      advertised.listeners=PLAINTEXT://192.168.157.130:9092
      log.dirs=/var/software/kafka/log
      zookeeper.connect=192.168.157.130:2181,192.168.157.131:2181,192.168.157.129:2181/myKafka
      
    • 第二台机器上配置

      xxx:~#vim /etc/profile
      # kafka
      export KAFKA_HOME=/opt/kafka_2.12-1.0.2
      export PATH=$PATH:$KAFKA_HOME/bin
      xxx:~#source /etc/profile
      xxx:~#vim /opt/kafka_2.12-1.0.2/config/server.properties
      broker.id=1
      listeners=PLAINTEXT://:9092
      advertised.listeners=PLAINTEXT://192.168.157.131:9092
      log.dirs=/var/software/kafka/log
      zookeeper.connect=192.168.157.130:2181,192.168.157.131:2181,192.168.157.129:2181/myKafka
      
    • 第三台机器上配置

      xxx:~#vim /etc/profile
      # kafka
      export KAFKA_HOME=/opt/kafka_2.12-1.0.2
      export PATH=$PATH:$KAFKA_HOME/bin
      xxx:~#source /etc/profile
      xxx:~#vim /opt/kafka_2.12-1.0.2/config/server.properties
      broker.id=2
      listeners=PLAINTEXT://:9092
      advertised.listeners=PLAINTEXT://192.168.157.129:9092
      log.dirs=/var/software/kafka/log
      zookeeper.connect=192.168.157.130:2181,192.168.157.131:2181,192.168.157.129:2181/myKafka
      
  2. 启动Kafka(三台机器均按如下操作)

    xxx:~#kafka-server-start.sh /opt/kafka_2.12-1.0.2/config/server.properties
    
  3. 验证Kafka(查看三台机器的Kafka启动过程中的Cluster ID是否一致)

    • Cluster Id是一个唯一的不可变的标志符,用于唯一标志一个Kafka集群。

    • 该Id最多可以有22个字符组成,字符对应于URL-safe Base64。

    • Kafka 0.10.1版本及之后的版本中,在集群第一次启动的时候,Broker从Zookeeper

      的<Kafka_ROOT>/cluster/id节点获取。如果该Id不存在,就自动生成一个新的。

    xxx:~#zkCli.sh
    [zk: localhost:2181(CONNECTED) 2] ls /myKafka/brokers/ids
    [0, 1, 2]
    [zk: localhost:2181(CONNECTED) 3] get /myKafka/brokers/ids/0
    {"listener_security_protocol_map":{"PLAINTEXT":"PLAINTEXT"},"endpoints":["PLAINTEXT://192.168.157.130:9092"],"jmx_port":-1,"host":"192.168.157.130","timestamp":"1629859078697","port":9092,"version":4}
    cZxid = 0x200000097
    ctime = Wed Aug 25 10:37:58 CST 2021
    mZxid = 0x200000097
    mtime = Wed Aug 25 10:37:58 CST 2021
    pZxid = 0x200000097
    cversion = 0
    dataVersion = 0
    aclVersion = 0
    ephemeralOwner = 0x200004838ed000a
    dataLength = 200
    numChildren = 0
    [zk: localhost:2181(CONNECTED) 4] get /myKafka/brokers/ids/1
    {"listener_security_protocol_map":{"PLAINTEXT":"PLAINTEXT"},"endpoints":["PLAINTEXT://192.168.157.131:9092"],"jmx_port":-1,"host":"192.168.157.131","timestamp":"1629859267652","port":9092,"version":4}
    cZxid = 0x20000010d
    ctime = Wed Aug 25 10:41:07 CST 2021
    mZxid = 0x20000010d
    mtime = Wed Aug 25 10:41:07 CST 2021
    pZxid = 0x20000010d
    cversion = 0
    dataVersion = 0
    aclVersion = 0
    ephemeralOwner = 0x300004845880007
    dataLength = 200
    numChildren = 0
    [zk: localhost:2181(CONNECTED) 5] get /myKafka/brokers/ids/2
    {"listener_security_protocol_map":{"PLAINTEXT":"PLAINTEXT"},"endpoints":["PLAINTEXT://192.168.157.129:9092"],"jmx_port":-1,"host":"192.168.157.129","timestamp":"1629859117629","port":9092,"version":4}
    cZxid = 0x2000000f8
    ctime = Wed Aug 25 10:38:37 CST 2021
    mZxid = 0x2000000f8
    mtime = Wed Aug 25 10:38:37 CST 2021
    pZxid = 0x2000000f8
    cversion = 0
    dataVersion = 0
    aclVersion = 0
    ephemeralOwner = 0x10000751a660004
    dataLength = 200
    numChildren = 0
    

Kafka集群搭建实战相关推荐

  1. Centos7 安装ELK/EFK 7.x 集群搭建实战攻略

    Centos7 安装ELK/EFK 7.x 集群搭建实战攻略 1.1 写在前面的话 1.2 开始之前 1.3 安装ELK/EFK 1.3.1 海量数据存储和检索-->E-->安装Elast ...

  2. 转-Kafka【第一篇】Kafka集群搭建

    转自: https://www.cnblogs.com/luotianshuai/p/5206662.html Kafka[第一篇]Kafka集群搭建 Kafka初识 1.Kafka使用背景 在我们大 ...

  3. kafka集群搭建(消息)

    1.Kafka使用背景 在我们大量使用分布式数据库.分布式计算集群的时候,是否会遇到这样的一些问题: 我们想分析下用户行为(pageviews),以便我们设计出更好的广告位 我想对用户的搜索关键词进行 ...

  4. zookeeper 和 kafka 集群搭建

    Kafka初识 1.Kafka使用背景 在我们大量使用分布式数据库.分布式计算集群的时候,是否会遇到这样的一些问题: 我们想分析下用户行为(pageviews),以便我们设计出更好的广告位 我想对用户 ...

  5. Zookeeper+Kafka集群搭建

    Zookeeper集群搭建 Kafka集群是把状态保存在Zookeeper中的,首先要搭建Zookeeper集群. 1.软件环境 (3台服务器-我的测试) 192.168.30.204 server1 ...

  6. kafka集群搭建教程(使用自带的zookeeper)

    kafka集群搭建教程(使用自带的zookeeper) 一.kafka简介 二.kafka名词解释 三.zookeeper与Kafka 四.kafka集群搭建前准备 1.下载 2.检验jdk 3.系统 ...

  7. kafka集群搭建+权限认证(SASL/SCRAM)+整合springboot

    本文介绍的的是kafka集群搭建.kafka权限认证(SASL/SCRAM).整合springboot项目. 1.创建kafka日志和zookeeper文件目录: /data/kafka/kafka- ...

  8. Kafka集群搭建及SASL/SCRAM,ACL权限控制

    Kafka集群搭建及SASL/SCRAM,ACL权限控制 环境 部署zookeeper集群及安全认证 部署kafka集群及安全认证 环境 系统版本:Centos7.4 kafka版本:kafka_2. ...

  9. Windows下Kafka集群搭建

    一.Windows下Zookeeper集群搭建. 1.集群版本:2.8.1,3.0版本不再支持JDK8,不在需要Zookeeper. 2.Zookeeper版本:3.8.0. 3.Zookeeper三 ...

最新文章

  1. python顺序执行多个py文件的方法
  2. Caffe代码导读(4):数据集准备
  3. BotVS开发基础—2.1 账户、行情、K线、深度
  4. python迭代器是什么百度百科,python迭代器的接口是什么?
  5. 高性能HTTP加速器Varnish(性能调优篇)
  6. 玩了10小时赛博朋克2077,我觉得很失望
  7. java中 自动输入一个按键_java-如何同时收听多个按键输入
  8. Document/View 模式下的窗口重绘
  9. HTML+CSS+JavaScript网页特效源代码(复制代码保存即可使用)
  10. excel首行空不能导入access_EXCEL数据无法导入ACCESS的解决办法
  11. python爬取景点信息_Python用Pyspider爬取TripAdvisor的景点信息
  12. 机器学习 | 特征选择(Feature Selection)
  13. Grafana——》重置默认的登录密码
  14. 如何将腾讯视频客户端下载的QLV视频格式转换成MP4格式
  15. win10u盘被写保护怎么解除_win10系统下u盘被写保护怎么解除_win10解除u盘写保护方法...
  16. 协议栈之packet_type
  17. 编写c语言数据从结构时头文件,C语言与数据结构 实验指导.doc
  18. element ui表格打印_element-ui 表格打印
  19. 1688-cat_get - 获得1688商品分类
  20. 解决类似微信聊天界面软键盘和表情框冲突问题

热门文章

  1. 虚拟机实现(C语言)
  2. 地下水采样需要用到什么?
  3. 信息安全概论(第3版)课后习题答案 牛少彰 崔宝江 李剑编著
  4. 除了刺激战场和全军出击,最近还有哪些好玩的手游值得推荐?
  5. 跳转物联平台,登录失败问题
  6. icc色彩配置文件_什么是色彩配置文件?
  7. Matlab模拟循环编码译码
  8. QXcbConnection: XCB error: 145 (Unknown), sequence: 171, resource id: 0 报错问题
  9. 上市后首份财报超预期,微盟2019年增长关键是走出微信
  10. Linux中命令提示符显示完整路径