Linux教程
  • Linux 教程
  • Linux 命令行
    • Linux 硬件管理
    • Linux 软件管理
    • 查看 Linux 命令帮助信息
    • Linux 系统管理
    • Linux 文件内容查看编辑
    • 命令行的艺术
    • Linux 文件压缩和解压
    • Linux 文件目录管理
    • Linux 用户管理
    • Linux 网络管理
  • 软件安装配置
    • JDK 安装
    • Elastic 技术栈
      • Elastic 技术栈之快速入门
      • Elastic 技术栈之 Logstash 基础
      • Elastic 技术栈之 Kibana
      • Elastic 技术栈之 Filebeat
    • Gitlab 安装
    • Jenkins 安装
    • Kafka 安装部署
    • Maven 安装
    • Nexus 运维
    • Mongodb 安装
    • Nodejs 安装
    • RocketMQ 安装部署
    • Svn 运维
    • Tomcat 安装
    • FastDFS
    • YApi 运维
    • Apollo
    • Nacos 安装配置
  • oh-my-zsh 应用
  • Iptables 应用
  • Linux 典型运维应用
  • Samba 应用
  • Vim 应用
  • Systemd 应用
  • Docker 教程
    • Kubernetes 应用指南
    • service
      • Docker 安装 MySQL
      • Docker 安装 Nginx
    • Docker Cheat Sheet
    • Dockerfile 最佳实践
    • Docker 快速入门
  • Shell 脚本大全
  • CentOS 常规操作运维脚本集合
    • 脚本使用说明
    • 构建、编译项目脚本
    • 服务安装配置
    • Git 脚本工具
Powered by GitBook
On this page
  • 下载解压
  • 启动服务器
  • 停止服务器
  • 创建主题
  • 生产者生产消息
  • 消费者消费消息
  • 集群部署
  • 更多内容

Was this helpful?

  1. 软件安装配置

Kafka 安装部署

PreviousJenkins 安装NextMaven 安装

Last updated 5 years ago

Was this helpful?

环境要求:

  • JDK8

  • ZooKeeper

下载解压

进入官方下载地址:

解压到本地:

> tar -xzf kafka_2.11-1.1.0.tgz
> cd kafka_2.11-1.1.0

现在您已经在您的机器上下载了最新版本的 Kafka。

启动服务器

由于 Kafka 依赖于 ZooKeeper,所以运行前需要先启动 ZooKeeper

> bin/zookeeper-server-start.sh config/zookeeper.properties
[2013-04-22 15:01:37,495] INFO Reading configuration from: config/zookeeper.properties (org.apache.zookeeper.server.quorum.QuorumPeerConfig)
...

然后,启动 Kafka

> bin/kafka-server-start.sh config/server.properties
[2013-04-22 15:01:47,028] INFO Verifying properties (kafka.utils.VerifiableProperties)
[2013-04-22 15:01:47,051] INFO Property socket.send.buffer.bytes is overridden to 1048576 (kafka.utils.VerifiableProperties)
...

停止服务器

执行所有操作后,可以使用以下命令停止服务器

$ bin/kafka-server-stop.sh config/server.properties

创建主题

创建一个名为 test 的 Topic,这个 Topic 只有一个分区以及一个备份:

> bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic test

生产者生产消息

运行生产者,然后可以在控制台中输入一些消息,这些消息会发送到服务器:

> bin/kafka-console-producer.sh --broker-list localhost:9092 --topic test
This is a message
This is another message

消费者消费消息

启动消费者,然后获得服务器中 Topic 下的消息:

> bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test --from-beginning
This is a message
This is another message

集群部署

复制配置为多份(Windows 使用 copy 命令代理):

> cp config/server.properties config/server-1.properties
> cp config/server.properties config/server-2.properties

修改配置:

config/server-1.properties:
    broker.id=1
    listeners=PLAINTEXT://:9093
    log.dir=/tmp/kafka-logs-1

config/server-2.properties:
    broker.id=2
    listeners=PLAINTEXT://:9094
    log.dir=/tmp/kafka-logs-2

其中,broker.id 这个参数必须是唯一的。

端口故意配置的不一致,是为了可以在一台机器启动多个应用节点。

根据这两份配置启动三个服务器节点:

> bin/kafka-server-start.sh config/server.properties &
...
> bin/kafka-server-start.sh config/server-1.properties &
...
> bin/kafka-server-start.sh config/server-2.properties &
...

创建一个新的 Topic 使用 三个备份:

> bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 3 --partitions 1 --topic my-replicated-topic

查看主题:

> bin/kafka-topics.sh --describe --zookeeper localhost:2181 --topic my-replicated-topic
Topic:my-replicated-topic   PartitionCount:1    ReplicationFactor:3 Configs:
    Topic: my-replicated-topic  Partition: 0    Leader: 1   Replicas: 1,2,0 Isr: 1,2,0
  • leader - 负责指定分区的所有读取和写入的节点。每个节点将成为随机选择的分区部分的领导者。

  • replicas - 是复制此分区日志的节点列表,无论它们是否为领导者,或者即使它们当前处于活动状态。

  • isr - 是“同步”复制品的集合。这是副本列表的子集,该列表当前处于活跃状态并且已经被领导者捕获。

更多内容

  • 引申

操作系统、运维部署总结系列
http://kafka.apache.org/downloads,选择合适版本。
下载解压
启动服务器
停止服务器
创建主题
生产者生产消息
消费者消费消息
集群部署