当前位置: 首页 > news >正文

redis全套参数配置及降级解决方案

文章目录

  • redis高可用核心参数配置
    • 1.Lettuce
    • 2.Jedis
    • 3.Redisson
    • 4.其他客户端
  • redis降级场景简介
  • 一、业务背景
  • 二、设计方案
  • 三、实现方案
  • 四、总结


redis高可用核心参数配置

1.Lettuce

提示:该客户端无主动探活机制,只能依赖于 OS KeepaAlive 机制,探测周期过长,且底层采用共享连接,遇到网络抖动或故障时,影响半径较大,强烈建议换为Jedis

2.Jedis

  • 需要通过设置连接探活机制缩短影响时间。建议将testWhileIdle设置为true;对于业务连接极端敏感的,并且节点连接数在5000以下(是节点连接数,不是集群连接数),testOnBorrow也可以配置为true;
  • 将Jedis版本升级到>=3.6.1;
  • Jedis全套高可用配置可参考另一篇。

3.Redisson

  • 需要通过设置连接探活机制缩短影响时间。建议将pingConnectionInterval调小,设置为3000ms;
  • 关闭读写分离。将readMode和subscriptionMode设置为MASTER;
  • 将Redission版本升级到>3.18.0;
  • Redission全套高可用配置可参考另一篇。

4.其他客户端

  • 其他客户端(Python、Node.js、PHP等)需要进行模拟测试Redis节点主备切换的情况下服务是否仍能正常连接redis

redis降级场景简介

提示:连接redis集群带有重试连接机制和实例转移连接机制,所以导致每一个请求中对redis的连接非常耗时

场景一:业务存在下游资源支撑如数据库或其他存储实例,这种情况只需要处理redis连接异常导致的接口请求超时问题,采用的方式为初次超时捕获连接异常后向监控系统抛出特定告警,打印日志。随后查询下游存储实例获取数据返回。告警向运维人员发送通知,修改逻辑参数后重启实例,使后续每次查询都直接访问下游存储实例避免浪费时间,同时安排redis恢复工作,待恢复好后修改再参数重启。

场景二:SDK里的redis损毁,无直接可用的下游存储实例支撑。处理方案为在SDK中维护一个本地缓存如caffeine,定时同步redis数据至本地缓存,当redis崩溃或连接超时直接访问本地缓存。或创建Redis数据的直接操作方系统,开启备用的接口调用,由第三方的系统服务加第三方数据库提供SDK-Redis降级支撑,最差的方案可以直接mock静态数据返回,满足核心业务流程不阻塞。


一、业务背景

  • 认证验权服务中台提供的用于分布式会话权限管理功能的SDK,里的redis组件存在崩溃风险,需要对其做出降级,用于支持在redis崩溃后,不影响某段时间内已登录过的用户的正常使用。可以拒绝登录业务流程

二、设计方案


三、实现方案


四、总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

http://www.lryc.cn/news/145201.html

相关文章:

  • AMD即将上市大量中端显卡,为新显卡支付过高价格的日子可能结束
  • go学习一之go的初体验
  • 智能制造产业链数字化转型、数字化互联工厂建设方案PPT
  • 【安卓】拿注册码的两种方式
  • 【C++】—— 异常处理
  • cookie和session是什么,区别是什么?
  • linux的mmc子系统与块设备关联
  • 【Spring MVC】
  • 【ES】笔记-生成器函数与调用
  • 将Spring Boot与Redis集成
  • vue echarts
  • idea上利用JDBC连接MySQL数据库(8.1.0版)
  • 【100天精通python】Day47:python网络编程_Web编程基础
  • DockerCompose介绍与使用
  • Windows Qt 5.12.10下载与安装
  • RustDesk最新版本编译与打包
  • Gin 框架入门实战系列(一)
  • 【测试】pywinauto的简单使用(安装、常用对象、元素控件、鼠标操作、键盘操作)
  • Java基础十八(正则表达式 + 日期时间)
  • Linux C 多进程编程(面试考点)
  • c++一级
  • Code Lab - 34
  • 后端返回文件流,前端怎么导出、下载(8种方法可实现)
  • 什么是 ThreadLocal?
  • CANOCO5.0实现冗余分析(RDA)最详细步骤
  • 【tkinter 专栏】掷骰子游戏
  • 19 NAT穿透|python高级
  • 2023常见前端面试题
  • 登录校验-JWT令牌-生成和校验
  • GIT 常用指令