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

SpringBoot集成kafka-消息转发@sendTo()注解

SpringBoot集成kafka-消息转发@sendTo

  • 1、消费者
  • 2、生产者
  • 3、实体类对象
  • 4、JSON工具类
  • 5、配置文件application.yml
  • 6、测试类
  • 7、测试

在这里插入图片描述在这里插入图片描述

1、消费者

  • 启动消费者进行消息监听,消费者A监听到生产者发送的消息
  • 使用@sendTo()注解将消息转发给消费者B
package com.power.consumer;import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.messaging.handler.annotation.SendTo;
import org.springframework.stereotype.Component;@Component
public class EventConsumer {@KafkaListener(topics = {"topicA"}, groupId = "aGroup")@SendTo("topicB")public String onEventA(ConsumerRecord<String, String> record) {System.out.println("消费者A接收消息,转发到消费者B record = " + record);return record.value() + "--forward message";}@KafkaListener(topics = {"topicB"}, groupId = "bGroup")public void onEventB(ConsumerRecord<String, String> record) {System.out.println("消费B消息接收到消费者A转发的消息 record = " + record);}}

2、生产者

package com.power.producer;import com.power.model.User;
import com.power.util.JSONUtils;
import org.springframework.kafka.core.KafkaTemplate;
import org.springframework.stereotype.Component;import javax.annotation.Resource;
import java.util.Date;@Component
public class EventProducer {@Resourceprivate KafkaTemplate<String,Object> kafkaTemplate;public void sendEvent(){User user = User.builder().id(1).phone("15676767673").birthday(new Date()).build();String userJson = JSONUtils.toJSON(user);kafkaTemplate.send("topicA","k", userJson);}}

3、实体类对象

package com.power.model;import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;import java.util.Date;@Builder
@AllArgsConstructor
@NoArgsConstructor
@Data
public class User {private Integer id;private String phone;private Date birthday;}

4、JSON工具类

package com.power.util;import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;public class JSONUtils {private static final ObjectMapper OBJECTMAPPER = new ObjectMapper();public static String toJSON(Object object){try {return OBJECTMAPPER.writeValueAsString(object);} catch (JsonProcessingException e) {throw new RuntimeException(e);}}public static <T> T toBean(String json,Class<T> clazz){try {return OBJECTMAPPER.readValue(json,clazz);} catch (JsonProcessingException e) {throw new RuntimeException(e);}}
}

5、配置文件application.yml

spring:application:#应用名称name: spring-boot-05-kafka-MsgRedirect#kafka连接地址(ip+port)kafka:bootstrap-servers: <你的kafak服务器IP>:9092#配置消费者的反序列化consumer:key-deserializer: org.apache.kafka.common.serialization.StringDeserializervalue-deserializer: org.apache.kafka.common.serialization.StringDeserializer

6、测试类

package com.power;import com.power.producer.EventProducer;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;import javax.annotation.Resource;@SpringBootTest
public class SpringBoot05KafkaBaseApplication {@Resourceprivate EventProducer eventProducer;@Testvoid sendInterceptor(){eventProducer.sendEvent();}}

7、测试

  • 先启动消费者进行消息监听
  • 再启动生产者发送消息

消费者A先接收到消息:
在这里插入图片描述

消费者B后接收到消费者A转发的消息:
在这里插入图片描述
在这里插入图片描述


http://www.mrgr.cn/news/10100.html

相关文章:

  • Bootstrap01----容器,网格系统,文字排版,颜色
  • C++学习笔记——交换值
  • 专利写作笔记
  • TCP 如何保证可靠性?
  • NYX靶机笔记
  • 机器学习——决策树,朴素贝叶斯
  • kafka随笔记
  • 轻空间火热征集:10位业主免费气膜设计!
  • USB3.2 摘录(九)
  • python文件批量生成pyd文件(pthon隐藏源码)
  • [从0开始AIGC][LLM]:LLM中Encoder-Only or Decoder-Only?为什么主流LLM是Decoder-Only?
  • 机械学习—零基础学习日志(如何理解概率论8)
  • 【SQL】直属部门
  • 四,接口类型和网络协议
  • Python实现核主成分分析(KPCA)降维算法
  • ASAM OpenX系列标准
  • 【多线程】如何保证多线程数据的安全性
  • 【数据结构5】二叉搜索树(插入、查询、删除)
  • 速盾的高防 IP 和 CDN 服务有哪些优势?
  • 除猫毛空气净化器什么牌子好?除猫毛宠物空气净化器测评推荐