【Kafka基础】生产者命令行操作指南:从基础到高级配置

Kafka作为分布式消息系统,其生产者是数据管道的起点。掌握kafka-console-producer.sh工具的使用对于开发测试和运维都至关重要。本文将系统介绍该工具的各种用法,帮助您高效地向Kafka发送消息。

1 基础消息生产

1.1 最简单的消息发送

复制代码
/export/home/kafka_zk/kafka_2.13-2.7.1/bin/kafka-console-producer.sh \
    --bootstrap-server 192.168.10.33:9092 \
    --topic testtopic

参数解析

  • --bootstrap-server: 指定Kafka集群地址
  • --topic: 指定目标主题名称
    特点
  • 交互式输入,每行作为一条消息
  • 按Ctrl+C退出
  • 消息无key,自动分配分区

1.2 从文件批量导入

复制代码
/export/home/kafka_zk/kafka_2.13-2.7.1/bin/kafka-console-producer.sh \
    --bootstrap-server 192.168.10.33:9092 \
    --topic testtopic \
    < messages.txt

特点

  • 将文件内容逐行作为消息发送
  • 适合数据迁移和批量测试

2 消息结构控制

2.1 带Key的消息发送

复制代码
/export/home/kafka_zk/kafka_2.13-2.7.1/bin/kafka-console-producer.sh \
    --bootstrap-server 192.168.10.33:9092 \
    --topic testtopic \
    --property parse.key=true \
    --property key.separator="\t"

关键参数

  • parse.key=true: 启用key解析
  • key.separator: 指定key/value分隔符(示例为制表符)

    输入格式:

    key1 value1
    key2 value2

2.2 自定义分隔符

复制代码
--property key.separator=":"

特点

  • 支持任意单字符分隔符
  • 确保分隔符不在key/value中出现

3 消息传递控制

3.1 指定目标分区

复制代码
--property partition=0

特点

  • 所有消息发送到指定分区
  • 绕过默认分区策略

3.2 同步发送模式

复制代码
--sync

特点

  • 每条消息等待服务器确认
  • 降低吞吐量,提高可靠性

4 高级生产者配置

4.1 消息压缩配置

复制代码
--property compression.type=gzip

可选值

  • none(默认)
  • gzip
  • snappy
  • lz4
  • zstd

4.2 时间戳配置

复制代码
--property timestamp.type=CreateTime

选项

  • CreateTime: 生产者创建时间(默认)
  • LogAppendTime: broker接收时间

5 可靠性配置

  • 高可靠性配置示例

    /export/home/kafka_zk/kafka_2.13-2.7.1/bin/kafka-console-producer.sh
    --bootstrap-server 192.168.10.33:9092
    --topic testtopic
    --producer-property acks=all
    --producer-property min.insync.replicas=2
    --producer-property enable.idempotence=true

关键参数

  • acks=all: 等待所有ISR确认
  • min.insync.replicas: 最小同步副本数
  • enable.idempotence: 启用幂等性

6 性能优化配置

  • 高性能配置示例

    /export/home/kafka_zk/kafka_2.13-2.7.1/bin/kafka-console-producer.sh
    --bootstrap-server 192.168.10.33:9092
    --topic testtopic
    --producer-property batch.size=65536
    --producer-property linger.ms=20
    --producer-property compression.type=lz4

优化参数

  • batch.size: 增大批次大小(字节)
  • linger.ms: 适当增加等待时间
  • compression.type: 选择高效压缩算法
相关推荐
武子康1 小时前
大数据-59 Kafka 拦截器全解析:原理、拦截链机制与自定义实现实战
大数据·后端·kafka
yuanzhengme13 小时前
Shell【脚本 02】离线安装配置Zookeeper及Kafka并添加service服务和开机启动(脚本分析)
linux·zookeeper·kafka·自动化·安装脚本
你我约定有三13 小时前
分布式微服务--Nacos作为配置中心(二)
java·分布式·spring cloud·微服务·架构·wpf·负载均衡
黄雪超14 小时前
Kafka——关于Kafka动态配置
大数据·分布式·kafka
bing_15815 小时前
如何利用 Redis 的原子操作(INCR, DECR)实现分布式计数器?
数据库·redis·分布式
阿明 -李明15 小时前
银行账户风险防控数字化的应用与实践
大数据·postgresql·flink·kafka
爱思德学术20 小时前
中国计算机学会(CCF)推荐学术会议-A(软件工程/系统软件/程序设计语言):FSE 2026
分布式·软件工程·软件构建
Code季风1 天前
API 网关与服务发现:实现动态路由与智能请求转发的原理揭秘
分布式·微服务
怒码ing1 天前
分布式事务----spring操作多个数据库,事务以及事务回滚还有用吗
数据库·分布式·spring
你我约定有三1 天前
分布式微服务--Nacos作为配置中心(一)
分布式·微服务·架构