Kafka 生产者和消费者入门代码基础
这篇博文讲解Kafka 的生产者和消费者实例。
基础版本一
生产者
ProducerFastStart.java
package com.xingyun.tutorial_1; import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.ProducerRecord; import java.util.Properties; public class ProducerFastStart { public static final String brokerList="192.168.10.137:9092"; // public static final String topic="topic-demo";
public static final String topic="ODS-PSR-P.*"; public static void main(String args[]){ //配置生产者客户端参数
//将配置序列化
Properties properties=new Properties();
properties.put("key.serializer","org.apache.kafka.common.serialization.StringSerializer");
properties.put("value.serializer","org.apache.kafka.common.serialization.StringSerializer");
properties.put("bootstrap.servers",brokerList); //创建KafkaProducer 实例
KafkaProducer<String,String> producer=new KafkaProducer<String, String>(properties); //构建待发送的消息
ProducerRecord<String,String> record=new ProducerRecord<String, String>(topic,"hello Kafka!");
try {
//尝试发送消息
producer.send(record);
//打印发送成功
System.out.println("send success from producer");
} catch (Exception e) {
e.printStackTrace();
}finally {
//关闭生产者客户端实例
producer.close();
}
}
}
消费者
ConsumerFastStart.java
package com.xingyun.tutorial_1; import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer; import java.time.Duration;
import java.util.Collections;
import java.util.Properties; public class ConsumerFastStart { // public static final String brokerList="192.168.10.137:9092";
public static final String brokerList="10.221.148.217:9092 ,10.221.148.217:9093 ,10.221.148.217:9094"; // public static final String topic="topic-demo";
public static final String topic="ODS-PSR-P.*"; public static final String groupId="group.demo"; public static void main(String args[]){ //设置消费组的名称
//将属性值反序列化
Properties properties=new Properties();
properties.put("key.deserializer","org.apache.kafka.common.serialization.StringDeserializer");
properties.put("value.deserializer","org.apache.kafka.common.serialization.StringDeserializer");
properties.put("bootstrap.servers",brokerList);
properties.put("group.id",groupId); //创建一个消费者客户端实例
KafkaConsumer<String,String> consumer=new KafkaConsumer<>(properties); //订阅主题
consumer.subscribe(Collections.singletonList(topic)); //循环消费消息
while (true){
ConsumerRecords<String,String> records=consumer.poll(Duration.ofMillis(1000));
for (ConsumerRecord<String,String> record:records){
System.out.println("receiver a message from consumer client:"+record.value());
}
}
}
}
升级版本一:
生产者
KafkaProducerAnalysis.java
package com.xingyun.tutorial_2; import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.clients.producer.ProducerRecord;
import org.apache.kafka.common.serialization.StringSerializer; import java.util.Properties; public class KafkaProducerAnalysis { public static final String brokerList="192.168.10.137:9092"; public static final String topic="topic-demo"; public static void main(String args[]){ //配置生产者客户端参数
Properties properties=initConfig(); //创建相应的生产者实例
KafkaProducer<String,String> producer=new KafkaProducer<>(properties); //构建待发送的消息 topic 和value 是必填项
ProducerRecord<String,String> record=new ProducerRecord<>(topic,"hello,Kafka!"); try {
//发送消息
producer.send(record);
} catch (Exception e) {
e.printStackTrace();
}finally {
//关闭生产者实例
producer.close();
} } /**
* 配置生产者客户端参数
* */
private static Properties initConfig() {
Properties properties=new Properties();
// properties.put("bootstrap.servers",brokerList);
properties.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,brokerList);
// properties.put("key.serializer","org.apache.kafka.common.serialization.StringSerializer");
properties.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());
//properties.put("value.serializer","org.apache.kafka.common.serialization.StringSerializer");
properties.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG,StringSerializer.class.getName());
//properties.put("client.id","producer.client.id.demo");//指定客户端ID
properties.put(ProducerConfig.CLIENT_ID_CONFIG,"producer.client.id.demo");//指定客户端ID
return properties;
} }
消费者
KafkaConsumerAnalysis.java
package com.xingyun.tutorial_2; import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import org.apache.kafka.common.serialization.Deserializer; import java.time.Duration;
import java.util.Arrays;
import java.util.Properties;
import java.util.concurrent.atomic.AtomicBoolean; public class KafkaConsumerAnalysis { public static final String brokerList="";
public static final String topic="topic-demo";
public static final String groupId="group.demo"; public static final AtomicBoolean isRunning=new AtomicBoolean(true); public static void main(String[] args){ //配置消费者客户端参数
Properties properties=initConfig(); //创建相应的消费者实例
KafkaConsumer<String,String> consumer=new KafkaConsumer<>(properties); //订阅主题
consumer.subscribe(Arrays.asList(topic)); try {
//拉取消息并消费
while(isRunning.get()){ ConsumerRecords<String,String> records=consumer.poll(Duration.ofMillis(1000)); for (ConsumerRecord<String,String> record:records){ System.out.println("topic="+record.topic()+",partition="+record.partition()+",offset="+record.offset());
System.out.println("key="+record.key()+",value="+record.value());
//do something to processor record.
}
}
} catch (Exception e) {
e.printStackTrace();
}finally {
consumer.close();
}
} /**
* 配置消费者客户端参数
* */
private static Properties initConfig() {
Properties properties=new Properties(); // properties.put("key.deserializer","org.apache.kafka.common.serialization.Deserializer");
properties.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, Deserializer.class.getName()); // properties.put("value.deserializer","org.apache.kafka.common.serialization.Deserializer");
properties.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG,Deserializer.class.getName()); //指定连接Kafka集群所需的broker地址清单,中间用逗号隔开,默认值为""
// properties.put("bootstrap.server",brokerList);
properties.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG,brokerList); //消费者所属的消费组的名称,默认值为""
// properties.put("group.id",groupId);
properties.put(ConsumerConfig.GROUP_ID_CONFIG,groupId); // properties.put("client.id","consumer.client.id.demo");
//指定消费者客户端Id,如果不设置,则自动生成consumer-1,consumer-2
properties.put(ConsumerConfig.CLIENT_ID_CONFIG,"consumer.client.id.demo"); return properties;
}
}
Kafka 生产者和消费者入门代码基础的更多相关文章
- kafka生产者和消费者api的简单使用
kafka生产者和消费者api的简单使用 一.背景 二.需要实现的功能 1.生产者实现功能 1.KafkaProducer线程安全的,可以在多线程中使用. 2.消息发送的key和value的序列化 3 ...
- [Spark][kafka]kafka 生产者,消费者 互动例子
[Spark][kafka]kafka 生产者,消费者 互动例子 # pwd/usr/local/kafka_2.11-0.10.0.1/bin 创建topic:# ./kafka-topics.sh ...
- kafka生产者和消费者流程
前言 根据源码分析kafka java客户端的生产者和消费者的流程. 基于zookeeper的旧消费者 kafka消费者从消费数据到关闭经历的流程. 由于3个核心线程 基于zookeeper的连接器监 ...
- kafka-python开发kafka生产者和消费者
1.安装kafka-python 执行命令 pip install kafka-python kafka-python 1.4.6 2.编写python kafka 生产者消费者代码 # ...
- kafka学习(三)kafka生产者,消费者详解
文章更新时间:2020/06/14 一.生产者 当我们发送消息之前,先问几个问题:每条消息都是很关键且不能容忍丢失么?偶尔重复消息可以么?我们关注的是消息延迟还是写入消息的吞吐量? 举个例子,有一个信 ...
- Kafka 生产者、消费者与分区的关系
背景 最近和海康整数据对接, 需要将海康产生的结构化数据拿过来做二次识别. 基本的流程: 海康大数据 --> kafka server --> 平台 Kafka 的 topic 正常过车 ...
- kafka生产者和消费者
在使用kafka时,有时候为验证应用程序,需要手动读取消息或者手动生成消息.这个时候可以借助kafka-console-consumer.sh和kafka-console-producer.sh 这两 ...
- springboot配置kafka生产者和消费者详解
在原有pom.xml依赖下新添加一下kafka依赖ar包 <!--kafka--> <dependency> <groupId>org.springframewor ...
- kafka生产者、消费者java示例
1. 生产者 import java.util.Properties; import kafka.javaapi.producer.Producer; import kafka.producer.Ke ...
随机推荐
- input模拟输入下拉框
功能点: 输入.下拉选择.根据输入内容模糊检索.键盘上下键选择 实现思路: 显示隐藏: input获取焦点显示,失去焦点隐藏 下拉选择: 以父元素为基准,通过绝对定位定位至input输入下方 模 ...
- Some Conclusions.
目录 DP 四边形不等式 数论 & 数学 数据结构 树链剖分 左偏树的性质及\(O(n)\)的构造 图论 树 二分图 竞赛图 平面图 双连通分量 字符串 后缀自动机 复杂度分析 没什么好写的. ...
- Sql的行列(纵横表)转换
1.行转列: 表结构和数据: DROP TABLE IF EXISTS `kj`; CREATE TABLE `kj` ( `姓名` ) DEFAULT NULL, `课程` ) DEFAULT NU ...
- Java笔记(九)EnumMap & EnumSet
EnumMap & EnumSet 一.EnumMap 一)基本用法 public static Map<Size, Integer> countBySize(List<Cl ...
- 潭州课堂25班:Ph201805201 tornado 项目 第三课 项目 图片上传,展示 (课堂笔记)
tornado 相关说明 f增加图片上传功能, 在 main.py ,文件中创建个 UploadHandler 类,用来处理图片上传 上传图片之前,要先渲染这个页面,所以定个 get 方法,把这个页 ...
- 用STM32CudeMX 点亮红色LED灯(软件操作步骤为主)
1.收获如何使用软件STM32CudeMX配置代码 注意:自己要敲的代码,直接看102行,其他是软件配置的.!!! /** ************************************** ...
- [HNOI2010]平面图判定
Description: 若能将无向图 \(G=(V, E)\) 画在平面上使得任意两条无重合顶点的边不相交,则称 \(G\) 是平面图.判定一个图是否为平面图的问题是图论中的一个重要问题.现在假设你 ...
- dd制作linux启动盘
1.fdisk /dev/sdb 删除分区,新建分区 2.mkfs.vfat /dev/sdb1 3.dd bs=4M if=CentOS.iso of=/dev/sdb
- 3ds max 学习笔记(四)--创建物体
添加物体: 1.初创建物体,从单视图进行创建,便于处于同一平面,在透视图观看效果.2.在基本对象处选择“长方体”:左键开始制作,松开左键此时控制的是长方形的高,然后点击左键完成:注:在max里点击右键 ...
- c# 后台绑定treeview 多个tab
<wijmo:C1Tabs ID="C1Tab1" runat="server" ><%--OnSelectedChanged="& ...