redis 的mq功能演示

本文通过实战演示了Redis提供的Pub/Sub功能,展示了如何使用两个终端分别实现消息的订阅与发布,适用于希望了解Redis消息队列基本用法的读者。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

redis-cli - Command-line client to redis-server
2.1. Pub/Sub 订阅与发布

redis 提供基本的MQ 功能,下面我们做一个演示

开启第一个终端窗口,订阅first second

$ redis-cli
redis 127.0.0.1:6379> SUBSCRIBE first second
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "first"
3) (integer) 1
1) "subscribe"
2) "second"
3) (integer) 2

开启第二个终端窗口,分别发送first second

$ redis-cli
redis 127.0.0.1:6379>  PUBLISH second Hello
(integer) 1
redis 127.0.0.1:6379>  PUBLISH first Helloworld!!!
(integer) 1
redis 127.0.0.1:6379> quit

现在切换到第一个终端窗口,应该能够看到发送过来的字符串

$ redis-cli
redis 127.0.0.1:6379> SUBSCRIBE first second
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "first"
3) (integer) 1
1) "subscribe"
2) "second"
3) (integer) 2

1) "message"
2) "second"
3) "Hello"

1) "message"
2) "first"
3) "Helloworld!!!"

转载于:https://my.oschina.net/neochen/blog/119504

### 使用 Spring Boot 整合 Redis 和消息队列的最佳实践 #### 添加依赖项 为了使 Spring Boot 项目能够与 Redis 结合并支持消息队列功能,需在 `pom.xml` 文件中加入必要的 Maven 依赖。这包括 Spring Data Redis 及其相关组件。 ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <!-- 如果要使用Redis作为消息中间件 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> ``` 上述代码片段展示了如何向项目的构建文件添加所需的库[^2]。 #### 配置 Redis 连接参数 编辑 application.properties 或者 application.yml 来指定 Redis 数据库的具体设置,例如主机地址、端口号等信息: ```yaml spring: redis: host: localhost port: 6379 ``` 此部分配置允许应用程序成功建立到 Redis Server 的网络链接[^1]。 #### 创建 RedisTemplate Bean 定义一个 Java 类用来初始化 RedisTemplate 对象实例,并对其进行自定义化调整以便更好地适应业务需求;还可以在此处注入 JedisConnectionFactory 或 LettuceConnectionFactory 以管理客户端会话池资源。 ```java @Configuration public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory){ RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(factory); Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<>(Object.class); ObjectMapper om = new ObjectMapper(); om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY); om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL); jackson2JsonRedisSerializer.setObjectMapper(om); template.setValueSerializer(jackson2JsonRedisSerializer); template.afterPropertiesSet(); return template; } } ``` 这段程序说明了怎样创建和配置 RedisTemplate bean,从而方便后续的操作过程。 #### 设计消息生产者服务层逻辑 下面给出了一种可能的方式去设计发送消息的服务接口及其具体实现方法——这里采用的是 List 数据结构模拟先进先出(FIFO)模式下的简单队列行为。 ```java @Service @Slf4j public class MessageProducerService { private final String QUEUE_NAME = "messageQueue"; private final RedisTemplate<String,Object> redisTemplate; @Autowired public MessageProducerService(RedisTemplate<String,Object> redisTemplate){ this.redisTemplate=redisTemplate; } /** * 向队尾追加一条新记录 */ public void sendMessage(String message){ log.info("Sending message '{}' to queue '{}'",message,QUEUE_NAME); redisTemplate.opsForList().rightPush(QUEUE_NAME,message); } } ``` 该段落描述了如何通过调用 RedisTemplate 提供的方法完成数据入栈动作,即实现了消息推送的功能[^5]。 #### 开发消费者监听器类 对于消费侧而言,则需要注册相应的事件处理器来接收来自特定主题的通知信号,并据此触发进一步的动作响应流程。此处举例说明当检测到列表头部存在未读条目时自动弹出并处理之的过程。 ```java @Component @RequiredArgsConstructor(onConstructor_=@Autowired) @Slf4j public class MessageConsumerListener implements ApplicationListener<ApplicationReadyEvent>{ private static final long SLEEP_TIME_MS = 1000L; //轮询间隔时间(ms) private final String QUEUE_NAME="messageQueue"; private final RedisTemplate<String,Object> redisTemplate; @Override public void onApplicationEvent(ApplicationReadyEvent event){ ScheduledExecutorService scheduler = Executors.newSingleThreadScheduledExecutor(); Runnable task=new Runnable(){ @Override public void run() { try{ while(true){ Long size=redisTemplate.opsForList().size(QUEUE_NAME);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值