SpringBoot使用Redis实现消息队列的方法小结
package cn.springdoc.demo.consumer;
import java.util.concurrent.TimeUnit;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Component;
@Component
public class OrderConsumer implements ApplicationRunner, Runnable {
static final Logger log = LoggerFactory.getLogger(OrderConsumer.class);
// 消息队列
final String queue = "queue_orders";
// pending 队列,即待确认消息的队列
final String pendingQueue = "pending_queue_orders";
@Autowired
StringRedisTemplate stringRedisTemplate;
@Override
public void run(ApplicationArguments args) throws Exception {
// 应用启动后,创建新的线程来执行消费任务
Thread thread = new Thread(this);
thread.setName("order-consumer-thread");
thread.start();
}
@Override
public void run() {
while (true) {
try {
// 1:消费者,从队列未弹出消息,并推送到 pending 队列,整个过程是原子性的
// 最多阻塞 5 秒,超过 5 秒后还没有消息,则返回 null
String item = stringRedisTemplate.opsForList().rightPopAndLeftPush(queue, pendingQueue, 5, TimeUnit.SECONDS);
if (item == null) {
log.info("等待消息 ...");
continue ;
}
try {
// 2:解析为 Long
Long orderId = Long.parseLong(item);
// 模拟消息消费
log.info("消费消息: {}", orderId);
} catch (Exception e) {
log.error("消费异常:{}", e.getMessage());
continue;
}
// 3:消费成功,从 pending 队列删除记录,相当于确认消费
stringRedisTemplate.opsForList().remove(pendingQueue, 0, item);
} catch (Exception e) {
log.error("队列监听异常:{}", e.getMessage());
break;
}
}
log.info("退出消费");
}
}
- .NET Core系列之MemoryCache 初识
- 007手机一键Root(安机网一键Root) v3.0 官方最新版 一键ROOT您的Android手机
- 12306密码被盗了怎么办?12306密码外泄解决方法
- 12个字的qq网名
- 150M迷你型无线路由器怎么设置?
- 192.168.1.1打不开怎么办?路由器192.168.1.1打不开的原因以及解决办法
- 2011年电子报合订本 电子报 编辑部 中文 PDF版 [84M]
- 2015年1月15日小米新旗舰发布会现场图文直播
- 2016.3.1vivo Xplay5新品发布会现场视频直播 优酷直播
- 2016华为P9发布会视频直播地址 4月15日华为P9国行发布会直播
相关文章
- SpringBoot自定义线程池,执行定时任务方式
- CalSprite(雪狐日历精灵) v1.55 豪华免费版
- Springboot中的Controller解析
- SpringBoot使用Redis实现消息队列的方法小结
- SpringBoot项目实现短信发送接口开发的实践
- Springboot读取外部配置文件,项目部署时配置读取不到问题及解决
- SpringBoot获取Request对象的常见方法
- SpringSecurity中的Filter Chain(过滤器链)
- spring webClient配置及使用简单代码示例
- SpringBoot、Java 使用 Jsoup 解析 HTML 页面的详细步骤