本文将介绍如何利用Spring Boot与Redis结合实现消息队列的在实际业务中实践例子。
消息队列是一种常用的解耦和异步通信的机制,可以在系统中实现高效的消息传递和处理。而Redis作为一种高性能的内存数据库,具备发布/订阅功能,非常适合用于构建消息队列系统。
核心源码
1、创建一个消息发布者
// 消息发布者
@Component
public class MessagePublisher {
private final RedisTemplate<String, String> redisTemplate;
private final ChannelTopic topic;
public MessagePublisher(RedisTemplate<String, String> redisTemplate, ChannelTopic topic) {
this.redisTemplate = redisTemplate;
this.topic = topic;
}
public void publishMessage(String message) {
redisTemplate.convertAndSend(topic.getTopic(), message);
}
}
当用户通过小程序授权登录注册时,访问后台服务接口的wxappLogin方法,调用发布者类RedisSqueueService中
doSomethingAndPublishMessage方法参传uid(用户Id)来发布消息(新注册用户添加赠送卡券)。
@Service
public class RedisSqueueService {
private final MessagePublisher messagePublisher;
public RedisSqueueService(MessagePublisher messagePublisher) {
this.messagePublisher = messagePublisher;
}
public void doSomethingAndPublishMessage(Long uid) {
// 执行一些操作
String message = uid.toString();
messagePublisher.publishMessage(message);
}
}
当调用redisSqueueService中的
doSomethingAndPublishMessage()方法时,消息将被发布到Redis的消息队列中,并由订阅者接收和处理。
this.userService.save(yxUser);
// redis发送消息队列,添加新注册用户赠送卡券
redisSqueueService.doSomethingAndPublishMessage(yxUser.getUid());
2、接下来,配置Redis消息监听容器,以便启动消息监听器
/**
* 配置Redis消息监听容器,以便启动消息监听器
*/
@Configuration
public class RedisMessageConfig {
@Bean
public ChannelTopic topic() {
return new ChannelTopic("messageQueue"); // 定义消息队列的通道名称
}
@Bean
public MessageListenerAdapter messageListenerAdapter(MessageSubscriber messageSubscriber) {
return new MessageListenerAdapter(messageSubscriber);
}
@Bean
public RedisMessageListenerContainer redisContainer(RedisConnectionFactory redisConnectionFactory,
MessageListenerAdapter messageListenerAdapter,
ChannelTopic topic) {
RedisMessageListenerContainer container = new RedisMessageListenerContainer();
container.setConnectionFactory(redisConnectionFactory);
container.addMessageListener(messageListenerAdapter, topic);
return container;
}
}
3、在订阅者类中,通过实现MessageListener接口来处理接收到的消息,处理新用户注册赠送卡券。
// 消息订阅者
@Component
public class MessageSubscriber implements MessageListener {
/**
* 卡券服务接口
*/
@Autowired
private CouponService couponService;
@Override
public void onMessage(Message message, byte[] pattern) {
String receivedMessage = message.toString();
// 处理接收到的消息
System.out.println("Received message: " + receivedMessage);
Integer userId = Integer.valueOf(receivedMessage);
MtCoupon coupon = new MtCoupon();
// 是否新注册赠送,A:是;D:否
coupon.setIsNewGive("A");
List<MtCoupon> list = couponService.queryCouponListByCondi(coupon);
if(list!=null && list.size()>0){
for(MtCoupon mtCoupon:list){
if(mtCoupon.getStoreIds()!=null||!"".equals(mtCoupon.getStoreIds())){
String[] storeIds = mtCoupon.getStoreIds().split(",");
for(String storeId : storeIds){
couponService.sendCoupon(mtCoupon.getId(), 1 , userId, Integer.parseInt(storeId));
}
}
}
}
}
}
注:在管理后台设置卡券是否新注册用户赠送标识,A:是;D:否
以上完成基本的消息发布和订阅流程。
总结:通过这种异步的方式,消息发布者和订阅者可以解耦,提高系统的可伸缩性和性能。
公众号搜索“讯音云商智能”,介绍更多无人自助共享空间系统功能。