当前位置: 首页 > news >正文

Kafka集群安装部署

简介

Kafka是一款分布式的、去中心化的、高吞吐低延迟、订阅模式的消息队列系统。

同RabbitMQ一样,Kafka也是消息队列。不过RabbitMQ多用于后端系统,因其更加专注于消息的延迟和容错。

Kafka多用于大数据体系,因其更加专注于数据的吞吐能力。

Kafka多数都是运行在分布式(集群化)模式下,所以课程将以3台服务器,来完成Kafka集群的安装部署。

安装

  1. 确保已经跟随前面的视频,安装并部署了JDK和Zookeeper服务

    Kafka的运行依赖JDK环境和Zookeeper请确保已经有了JDK环境和Zookeeper

  2. 【在ip1操作】下载并上传Kafka的安装包

    # 下载安装包
    wget http://archive.apache.org/dist/kafka/2.4.1/kafka_2.12-2.4.1.tgz
  3. 【在ip1操作】解压

    mkdir -p /export/server         # 此文件夹如果不存在需先创建
    ​
    # 解压
    tar -zxvf kafka_2.12-2.4.1.tgz -C /export/server/
    ​
    # 创建软链接
    ln -s /export/server/kafka_2.12-2.4.1 /export/server/kafka
  4. 【在ip1操作】修改Kafka目录内的config目录内的server.properties文件

    cd /export/server/kafka/config
    # 指定broker的id
    broker.id=1
    # 指定 kafka的绑定监听的地址
    listeners=PLAINTEXT://ip1:9092
    # 指定Kafka数据的位置
    log.dirs=/export/server/kafka/data
    # 指定Zookeeper的三个节点
    zookeeper.connect=ip1:2181,ip2:2181,ip3:2181
  5. 【在ip1操作】将ip1的kafka复制到ip2和ip3

    cd /export/server
    ​
    # 复制到ip2同名文件夹
    scp -r kafka_2.12-2.4.1 ip2:`pwd`/
    # 复制到ip3同名文件夹
    scp -r kafka_2.12-2.4.1 ip3:$PWD
  6. 【在ip2操作】

    # 创建软链接
    ln -s /export/server/kafka_2.12-2.4.1 /export/server/kafka
    ​
    cd /export/server/kafka/config
    # 指定broker的id
    broker.id=2
    # 指定 kafka的绑定监听的地址
    listeners=PLAINTEXT://ip2:9092
    # 指定Kafka数据的位置
    log.dirs=/export/server/kafka/data
    # 指定Zookeeper的三个节点
    zookeeper.connect=ip1:2181,ip2:2181,ip3:2181
  7. 【在ip3操作】

    # 创建软链接
    ln -s /export/server/kafka_2.12-2.4.1 /export/server/kafka
    ​
    cd /export/server/kafka/config
    # 指定broker的id
    broker.id=3
    # 指定 kafka的绑定监听的地址
    listeners=PLAINTEXT://ip3:9092
    # 指定Kafka数据的位置
    log.dirs=/export/server/kafka/data
    # 指定Zookeeper的三个节点
    zookeeper.connect=ip1:2181,ip2:2181,ip3:2181
  8. 启动kafka

    # 请先确保Zookeeper已经启动了
    ​
    # 方式1:【前台启动】分别在ip1、2、3上执行如下语句
    /export/server/kafka/bin/kafka-server-start.sh /export/server/kafka/config/server.properties
    ​
    # 方式2:【后台启动】分别在ip1、2、3上执行如下语句
    nohup /export/server/kafka/bin/kafka-server-start.sh /export/server/kafka/config/server.properties 2>&1 >> /export/server/kafka/kafka-server.log &
  9. 验证Kafka启动

    # 在每一台服务器执行
    jps

测试Kafka能否正常使用

  1. 创建测试主题

# 在ip1执行,创建一个主题
/export/server/kafka_2.12-2.4.1/bin/kafka-topics.sh --create --zookeeper ip1:2181 --replication-factor 1 --partitions 3 --topic test
  1. 运行测试,请在FinalShell中打开2个ip1的终端页面

# 打开一个终端页面,启动一个模拟的数据生产者
/export/server/kafka_2.12-2.4.1/bin/kafka-console-producer.sh --broker-list ip1:9092 --topic test
# 再打开一个新的终端页面,在启动一个模拟的数据消费者
/export/server/kafka_2.12-2.4.1/bin/kafka-console-consumer.sh --bootstrap-server ip1:9092 --topic test --from-beginning

3.在数据生产者这边输入任意文本回车

4.在数据消费者这边接收到了信息

相关文章:

  • 嵌入式linux sqlite3读写demo
  • 【面试题】网络IO模型
  • 从0开始学习pyspark--Spark DataFrame数据的选取与访问[第5节]
  • jmeter-beanshell学习1-vars使用获取变量和设置变量
  • go内存返还系统相关代码
  • 001 进程和线程
  • Ruby 环境变量
  • 手写SpringMVC之调度器DispatcherServlet
  • Web3 ETF的主要功能
  • 开源205W桌面充电器,140W+65W升降压PD3.1快充模块(2C+1A口),IP6557+IP6538
  • docker pull 镜像的时候遇到Pulling fs layer问题
  • Eigen 欧拉角转旋转矩阵相互转换
  • SpringBoot整合Dubbo的快速使用教程
  • 嵌入式MCU平台汇总
  • 视频编解码从H.264到H.266:浅析GB28181安防视频汇聚EasyCVR视频压缩技术
  • 自己简单写的 事件订阅机制
  • Android框架之Volley
  • extjs4学习之配置
  • golang中接口赋值与方法集
  • HTTP请求重发
  • iOS编译提示和导航提示
  • MySQL QA
  • open-falcon 开发笔记(一):从零开始搭建虚拟服务器和监测环境
  • PHP 的 SAPI 是个什么东西
  • Protobuf3语言指南
  • Python 基础起步 (十) 什么叫函数?
  • scrapy学习之路4(itemloder的使用)
  • TypeScript实现数据结构(一)栈,队列,链表
  • 从地狱到天堂,Node 回调向 async/await 转变
  • 分享几个不错的工具
  • 技术发展面试
  • 看域名解析域名安全对SEO的影响
  • 力扣(LeetCode)21
  • 如何在 Tornado 中实现 Middleware
  • 推荐一款sublime text 3 支持JSX和es201x 代码格式化的插件
  • 没有任何编程基础可以直接学习python语言吗?学会后能够做什么? ...
  • ​​​​​​​GitLab 之 GitLab-Runner 安装,配置与问题汇总
  • ​iOS实时查看App运行日志
  • !!Dom4j 学习笔记
  • # Swust 12th acm 邀请赛# [ K ] 三角形判定 [题解]
  • #define 用法
  • #include<初见C语言之指针(5)>
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • $ git push -u origin master 推送到远程库出错
  • (12)目标检测_SSD基于pytorch搭建代码
  • (3)(3.2) MAVLink2数据包签名(安全)
  • (三)elasticsearch 源码之启动流程分析
  • (十八)三元表达式和列表解析
  • (一)ClickHouse 中的 `MaterializedMySQL` 数据库引擎的使用方法、设置、特性和限制。
  • ./configure、make、make install 命令
  • .NET Core 2.1路线图
  • .net core webapi 部署iis_一键部署VS插件:让.NET开发者更幸福
  • .NET 的静态构造函数是否线程安全?答案是肯定的!
  • .NET/C# 在代码中测量代码执行耗时的建议(比较系统性能计数器和系统时间)...
  • .NET开源项目介绍及资源推荐:数据持久层