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 的话,服务器端也会关闭客户端连接。

上一篇:lodash-es 基本使用


下一篇:秋招突击——7/8——复习{快速排序模版题——数组中第K大的元素、LRU缓存的实现}——新作{单调栈模版题——每日温度}-引言