springboot 程序运行一段时间后收不到redis订阅的消息

springboot 程序运行一段时间后收不到redis订阅的消息

问题描述

程序启动后redis.user.two主题正常是可以收到消息的,发一条收一条,但是隔一段时间后;就收不到消息了;

此时如果你手动调用发送另外一个消息订阅redis.user.two2,发现可以正常收到消息;

或者重启后redis.user.two也又可以正常收到消息了

代码截图

image-20240628151151479

image-20240628151210045

image-20240628151222800

image-20240628151247924

问题原因

此问题可能是由于,redis输出缓存区设置太小了,导致发送过快,消费太慢,redis由于自身保护机制,自动断开了连接

解决方法

优化代码,增加消费者

扩大输出缓存区大小,可以扩大一倍变成

67108864 16777216 60

image-20240628151632753

client-output-buffer-limit pubsub 8mb 2mb 60

pubsub 参数表示当前是对订阅客户端进行设置;8mb 表示输出缓冲区的大小上限为 8MB,一旦实际占用的缓冲区大小要超过 8MB,服务器端就会直接关闭客户端的连接;2mb 和 60 表示连续 60 秒内对输出缓冲区的写入量超过 2MB 的话,服务器端也会关闭客户端连接。

Spring Boot 中可以利用 Spring 的 `ThreadPoolTaskExecutor` 或者第三方库如 `Spring Cloud Task` 实现 Redis 订阅异步处理消息。以下是基本步骤: 1. 配置 ThreadPoolTaskExecutor 或创建一个自定义线程池: ```java @Bean public ThreadPoolTaskExecutor redisThreadPoolExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); executor.setCorePoolSize(5); // 核心线程数 executor.setMaxPoolSize(10); // 最大线程数 executor.setQueueCapacity(100); // 队列容量 executor.setThreadNamePrefix("redis-async-task-"); executor.initialize(); return executor; } ``` 2. 创建一个 Runnable 接口实现类,用于处理 Redis消息: ```java public class RedisMessageHandler implements Runnable { private final String channel; private final RedisTemplate<String, Object> redisTemplate; public RedisMessageHandler(String channel, RedisTemplate<String, Object> redisTemplate) { this.channel = channel; this.redisTemplate = redisTemplate; } @Override public void run() { List<String> messages = redisTemplate.opsForSubscription().subscribe(channel); for (String message : messages) { handleMessage(message); } } // 处理接收到的消息逻辑 private void handleMessage(String message) { // ... your handling logic here } } ``` 3. 异步监听 Redis 更新并发送到线程池执行: ```java @EventListener public void onRedisMessage(RedisMessageEvent event) { String channel = event.getChannel(); // 获取频道名 redisThreadPoolExecutor().execute(new RedisMessageHandler(channel, context.getBean(RedisTemplate.class))); } ``` 4.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值