SpringBoot基于Redis的发布订阅

SpringBoot基于Redis的发布订阅

1.导入Redis依赖

<!-- SpringBoot整合Redis -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

2.修改Redis配置

# 配置redis
spring.redis.host=localhost
spring.redis.port=6379

3.自定义RedisTamplate

/*
* 自定义RedisTamplate
* */

@Configuration
public class RedisConfig {

    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
        // 将template 泛型设置为 <String, Object>
        RedisTemplate<String, Object> template = new RedisTemplate();
        // 连接工厂,不必修改
        template.setConnectionFactory(redisConnectionFactory);
        /*
         * 序列化设置
         */
        // key、hash的key 采用 String序列化方式
        template.setKeySerializer(RedisSerializer.string());
        template.setHashKeySerializer(RedisSerializer.string());
        // value、hash的value 采用 Jackson 序列化方式
        template.setValueSerializer(RedisSerializer.json());
        template.setHashValueSerializer(RedisSerializer.json());
        template.afterPropertiesSet();
        
        return template;
    }
}

4.发布者

Publisher接口

/*
* 发布者
* */
public interface Publisher {
    void sendMsg(String topic, String msg);
}

Mypublisher类

@Service
public class MyPublisher implements Publisher {

    @Autowired
    public RedisTemplate<String, Object> redisTemplate;

    @Override
    public void sendMsg(String topic, String msg) {
        redisTemplate.convertAndSend(topic, msg);
    }
}

5.订阅者

1)配置RedisMessageListenerContainer容器

    /*
    * 配置RedisMessageListenerContainer容器
    * */
    @Bean
    RedisMessageListenerContainer redisContainer(RedisConnectionFactory factory) {
        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        container.setConnectionFactory(factory);
        return container;
    }

2)定义消息监听器,需要实现MessageListener接口

@Component
public class MsgListener implements MessageListener {

    @Override
    public void onMessage(Message message, byte[] pattern) {
        System.out.println("Message received: " + message.toString());
    }
}

3)SubScriber订阅者类

@Service
public class SubScriber {

    @Autowired
    private RedisMessageListenerContainer container;

    public void subScribe(String topic){
        //订阅频道
        container.addMessageListener(new MsgListener(), new ChannelTopic(topic));
    }
}

6.测试Controller

@RestController
public class MsgController {
        @Autowired
        private MyPublisher publisher;

        @Autowired
        private SubScriber subScriber;

        @RequestMapping("/sendMsg/{msg}")
        public String sendMsg(@PathVariable("msg") String msg){
            publisher.sendMsg("mjj", msg);
            return "发布成功!";
        }

        @RequestMapping("/subChannel/{topic}")
        public String subChannel(@PathVariable("topic") String topic){
            subScriber.subScribe(topic);
            return "订阅成功!";
        }
}
localhost:8080/subChannel/mjj
http://localhost:8080/sendMsg/123456

控制台输出:

image-20210427130858732

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值