RTpoic简介:
RTpoic 是 Redisson 提供的用于实现发布-订阅(Pub/Sub)模式的类,它封装了 Redis 的发布和订阅功能,让开发者能够轻松地在分布式环境中进行消息的发布和订阅。
实际上类似于Kafka、RocketMQ等一系列MessageQueue的生产-消费关系。
自产自销:简单的说,可以实现一个服务中,自己发布消息,自己订阅消息进行消息的分发处理。
代码示例:
1、引入redisson依赖
<!-- redis -->
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson-spring-boot-starter</artifactId>
<version>3.15.5</version>
</dependency>
2、创建一个指定发布-订阅的真实类型
/**
* 功能:监听器指定泛型类
*/
@Data
public class RTopicMsgEvent implements Serializable {
private static final long serialVersionUID = -1L;
private String orderNo;
}
3、创建一个主题监听器
/**
* 功能:主题消息监听器
*/
@Slf4j
@Service
public class RTopicListener implements MessageListener<RTopicMsgEvent> {
public static final String TOPIC = "myRTopic";
@Override
public void onMessage(CharSequence charSequence, RTopicMsgEvent rTopicMsgEvent) {
// 订阅到的消息
System.out.println(rTopicMsgEvent.getOrderNo());
}
}
4、注册Bean
/**
* 功能:RTopic配置类
*/
@Slf4j
@Configuration
public class RTopicConfiguration {
@Autowired
RedissonClient redissonClient;
@Autowired
RTopicListener rTopicListener;
/**
* addListener:泛型类、监听器
* @return
*/
@Bean("rTopicMsgEventHandel")
public RTopic redisDownMsgEventTopic() {
/* 发布对应的主题 */
RTopic topic = redissonClient.getTopic(RTopicListener.TOPIC);
/* 对该主题添加监听器 */
topic.addListener(RTopicMsgEvent.class, rTopicListener);
return topic;
}
}
————————————————
当某主题的消息被发布到对应主题后,对应主题的泛型类监听器将会对消息进行监听。
标签:订阅,Redisson,主题,class,消息,监听器,RTopic From: https://www.cnblogs.com/m-zone/p/18087450