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

相关推荐

  1. 【Android】EventBus消息种情况

    2024-07-15 17:34:01       29 阅读
  2. Springboot整合Redis实现消息发布订阅

    2024-07-15 17:34:01       55 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-15 17:34:01       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-15 17:34:01       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-15 17:34:01       58 阅读
  4. Python语言-面向对象

    2024-07-15 17:34:01       69 阅读

热门阅读

  1. pandas读取超过16位的excle

    2024-07-15 17:34:01       17 阅读
  2. blinker库

    2024-07-15 17:34:01       19 阅读
  3. 如何使用断点续传方式上传大文件到阿里云 OSS

    2024-07-15 17:34:01       15 阅读
  4. Web打点技术的攻击手段和渗透测试工具

    2024-07-15 17:34:01       21 阅读
  5. 游戏开发面试题2

    2024-07-15 17:34:01       19 阅读
  6. linux系统调用

    2024-07-15 17:34:01       22 阅读
  7. git安装

    git安装

    2024-07-15 17:34:01      20 阅读
  8. 2# 监控都不管用

    2024-07-15 17:34:01       17 阅读
  9. 线程同步的使用(二)

    2024-07-15 17:34:01       17 阅读
  10. 了解动力转向油封

    2024-07-15 17:34:01       17 阅读
  11. Solon v2.8.5 发布

    2024-07-15 17:34:01       18 阅读
  12. Python中的 NumPy与Pandas库介绍

    2024-07-15 17:34:01       16 阅读
  13. GE DS200DCCAG4模块 控制器 处理器

    2024-07-15 17:34:01       18 阅读
  14. CentOS7 使用conda

    2024-07-15 17:34:01       24 阅读