3.Redis实现发布订阅

发布订阅是消息的一种常用模式。常用的就有ActiveMQ,其实Redis也能实现发布订阅。首先Redis提供一个渠道,让消息能够发送到这个渠道上,而多个系统就可以监听这个渠道,如短信信通、邮件系统等。当一条消息发送到渠道是,渠道就会通知他的监听者,这样短信系统、邮件系统就可以得到这个渠道给他们消息,这些监听者在根据自己的处理逻辑处理这些消息。

  • 为了接收Redis渠道发送过来的消息,我们首先需要定义一个消息监听器(MessageListener):
@Component
public class MyRedisMessageListener implements MessageListener {
    @Override
    public void onMessage(Message message, byte[] bytes) {
        String messageBoby = new String(message.getBody());
        String topic = new String(bytes);
        System.out.println("从"+topic+"通道获取到消息:"+messageBoby);
    }
}
  • 然后我们在系统中配置其他信息,让系统能够不监控Redis的消息:
@Configuration
public class MyRedisListenerConfiguration {

    @Autowired
    private MyRedisMessageListener myRedisMessageListener;

    @Autowired
    private RedisConnectionFactory redisConnectionFactory;

	//任务池
    private ThreadPoolTaskScheduler threadPoolTaskScheduler;

	/**
	*创建任务池,运行线程等待处理Redis消息
	*/
    @Bean
    public ThreadPoolTaskScheduler getThreadPoolTaskScheduler() {
        if (threadPoolTaskScheduler != null) {
            return threadPoolTaskScheduler;
        }
        threadPoolTaskScheduler = new ThreadPoolTaskScheduler();
        threadPoolTaskScheduler.setPoolSize(10);
        return threadPoolTaskScheduler;
    }


	//定义Redis的监听容器
    @Bean
    public RedisMessageListenerContainer getContainer(){
        RedisMessageListenerContainer container=new RedisMessageListenerContainer();
        container.setConnectionFactory(redisConnectionFactory);
        container.setTaskExecutor(threadPoolTaskScheduler);
        container.setTopicSerializer(new StringRedisSerializer());
        container.addMessageListener(myRedisMessageListener,new ChannelTopic("topic1"));
        return container;
    }
}

这里的redisConnectionFactory是springBoot自动创建的,所以这里只需要将他们注入进来。然后定义一个任务池,并设置任务池的大小为10,这样他就可以运行线程,并进行阻塞,等待Redis消息的传入。接着再定义一个Redis消息的监听容器RedisMessageListenerContainer ,并且让容器中设置了Redis连接工厂和指定运行消息的线程池,定义了接收“topic1”渠道的消息,这样就可以监听Redis关于“topic1”渠道的消息。
若希望Redis监听容器可以监听多个渠道,可以传入一个Topic集合:
源码:
在这里插入图片描述

  • 接下来就可以进行测试了
    (1)在redis客户端中
publish  topic1  message

(2)使用redisTemplate
redisTemplate.convertAndSend(“topic1”,“message”);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SSM(Spring+Spring MVC+MyBatis)框架和Redis数据库通常可以结合使用以实现发布订阅功能。 发布订阅模式是一种面向消息的通信方式,多个接收者监听同一个主题,当主题发布消息时,所有接收者都会接收到通知并执行相应的操作。Redis发布订阅功能是Redis提供的一种基于事件驱动的消息通知机制,可以让多个客户端同时接收系统事件的通知。 在SSM框架中,可以使用Spring框架的事件驱动机制来实现发布订阅功能。具体地,可以在Spring框架的配置文件中配置一个事件监听器(Event Listener),该监听器会监听指定的事件。当该事件发生时,监听器会接收到事件通知,并执行相应的业务逻辑。例如,可以将Redis的发布消息事件(PUBLISH)作为Spring事件,然后在事件监听器中实现对该事件的处理逻辑。 在Redis中,可以使用PUBLISH命令向指定的频道(Channel)发布消息。多个客户端可以使用SUBSCRIBE命令来订阅指定的频道,当有消息发布到该频道时,所有订阅该频道的客户端都会接收到该消息。 因此,在SSM和Redis实现发布订阅功能的步骤大致可以分为以下几步: 1. 配置Redis连接信息,以便SSM框架能够正确连接到Redis数据库。 2. 在Spring框架的配置文件中定义一个事件监听器,该监听器将监听Redis的发布事件。 3. 在监听器中编写事件处理逻辑,例如向所有订阅了该频道的客户端发送指定的消息。 4. 在应用程序中使用PUBLISH命令向指定的频道发布消息,或使用SUBSCRIBE命令订阅指定的频道。 通过以上步骤,便可以在SSM框架和Redis数据库中实现发布订阅功能。该功能可用于实现实时消息推送、事件通知等功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值