Spring Boot学习:Redis发布订阅

Redis发布订阅

Redis 2.8 及以上版本实现了发布订阅的功能,发送者可以通过 PUBLISH发布消息,订阅者通过 SUBSCRIBE 订阅接收消息或通过UNSUBSCRIBE 取消订阅。当发布者发布消息到指定频道时,所有订阅该频道的订阅者都能够接收到消息。这对于实时通信、聊天应用、实时数据更新等场景非常有用。

Redis发布订阅实现

下面我就在Spring Boot项目中使用Redisson 来实现发布订阅
1、添加redisson依赖,依赖如下

		<dependency>
            <groupId>org.redisson</groupId>
            <artifactId>redisson</artifactId>
            <version>3.16.8</version>
        </dependency>

2、创建Redisson客户端

我们需要创建一个Redisson客户端实例来使用Redisson,一般通过在Spring Boot配置文件中添加Redisson客户端的配置来创建它

下面是一个简单的配置示例

@Configuration  
public class RedissonConfig {  
    @Value("${redisson.address}")  
    private String address;  
  
    @Bean(destroyMethod="shutdown")  
    RedissonClient redisson() throws IOException {  
        Config config = new Config();  
        config.useSingleServer().setAddress(address);  
        return Redisson.create(config);  
    }  
}

3、创建发布者

接下来,您需要创建一个发布者类,用于向指定的频道发布消息。您可以使用Redisson客户端的getTopic方法获取指定的频道,并使用publish方法发布消息。例如:

@Service  
public class Publisher {  
    @Autowired  
    private RedissonClient redissonClient;  
  
    /**
     * 发布消息到 Topic
     * @param topicName Topic名称
     * @param message 消息体
     */
    public void publish(String topicName, String message) {
        RTopic topic = redissonClient.getTopic(topicName);
        topic.publish(message);
    }

}

4、创建消息监听器类

为了定义接收到消息后的处理逻辑,还需要创建一个消息监听器接口(MessageListener)的实现类,实现onMessage方法来定义我们的消息处理逻辑

@Slf4j
@Component
public class MyMessageListener implements org.redisson.api.listener.MessageListener<String> {

    /**
     * 消息处理
     * @param channel
     * @param msg
     */
    @Override
    public void onMessage(CharSequence channel, String msg) {
        log.info("监听到消息:"+msg);
    }
}

5、创建订阅者

最后,您需要创建一个订阅者类,用于订阅指定的频道并处理接收到的消息。您可以使用Redisson客户端的getTopic方法获取指定的频道,并使用addListener方法添加消息监听器。例如:

@Slf4j
@Component
public class Subscriber{

    /**
     * 主题名称
     */
    public static final String TOPIC_NAME = "test_topic";

    @Autowired
    private RedissonClient redissonClient;

    @Autowired
    private MyMessageListener myMessageListener;

    /**
     * 订阅主题
     */
    @PostConstruct
    public void init() {
        redissonClient.getTopic(TOPIC_NAME)
                .addListener(String.class, myMessageListener);
    }

    /**
     * 订阅主题
     * @param topicName 主题名
     * @param type      消息类型
     * @param listener  监听器
     */
    public void subscribeTopic(String topicName, Class type, MessageListener listener) {
        RTopic topic = redissonClient.getTopic(topicName);
        topic.addListener(type,listener);
    }
}

@PostConstruct 是Java中的一个注解,用于标记在依赖注入完成后,应该执行的方法。这个注解通常用于在Spring或Java EE环境中,当一个bean被初始化并完成依赖注入后,执行一些初始化的操作。

这里是在初始化的时候先订阅一些我们需要使用的主题

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot中使用Redis进行发布订阅可以通过以下步骤实现: 1. 配置Redis连接信息 在application.properties文件中配置Redis连接信息,包括Redis的IP地址、端口号、密码等。 ``` spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password= ``` 2. 配置RedisTemplate 在Spring Boot中使用Redis需要使用到RedisTemplate,可以通过以下方式进行配置: ``` @Configuration public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); redisTemplate.setConnectionFactory(factory); redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer()); return redisTemplate; } } ``` 上述代码中,我们配置了RedisTemplate的序列化方式,使用了StringRedisSerializer和GenericJackson2JsonRedisSerializer进行序列化。 3. 实现发布者 通过RedisTemplate实现发布者,可以使用convertAndSend方法进行消息发布。 ``` @Service public class RedisPublisher { @Autowired private RedisTemplate<String, Object> redisTemplate; public void publish(String channel, Object message) { redisTemplate.convertAndSend(channel, message); } } ``` 上述代码中,通过@Autowired注入了RedisTemplate,并实现了publish方法,通过convertAndSend方法实现了消息的发布。 4. 实现订阅者 通过@RedisListener注解实现订阅者,可以监听Redis中指定的频道,实现消息的订阅。 ``` @Service public class RedisSubscriber { @RedisListener(channel = "test") public void onMessage(Object message) { System.out.println("Received Message: " + message); } } ``` 上述代码中,通过@RedisListener注解指定了监听的频道,实现了onMessage方法,当Redis中有消息发布到该频道时,该方法会被回调。 5. 测试 在Spring Boot中测试Redis发布订阅可以通过以下方式: ``` @RunWith(SpringRunner.class) @SpringBootTest public class RedisTest { @Autowired private RedisPublisher redisPublisher; @Test public void testPublish() { redisPublisher.publish("test", "Hello World!"); } } ``` 上述代码中,通过@Autowired注入了RedisPublisher,实现了testPublish方法,调用publish方法发布了一条消息到test频道中。 运行测试后,可以在RedisSubscriber的onMessage方法中看到收到了发布的消息。 以上就是Spring Boot中使用Redis进行发布订阅的详细步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值