如何在生产环境正确使用Redis

一、在生产环境使用Redis

如果在生产环境使用Redis,需要遵守一定的使用规范,以保障服务稳定、高效。。

1.1、明确Redis集群的服务定位

1、仅适用于缓存场景Redis定位于高性能缓存服务,强调快速读写和低延迟的特性,主要用于数据的快速存取,提升系统的响应速度Redis本身不具备持久化能力,因此不建议用于大规模冷数据、持久化的存储场景。

2、避免共用Redis集群:为避免相互影响和增加问题排查成本,不同业务不能共用Redis集群,确保业务间的隔离性,以便更容易定位和解决潜在的问题,提高系统的稳定性和可维护性。

1.2、合理利用Redis容灾能力

1、多副本容灾Redis基于分片内多副本进行数据容灾。当分片内只包含一个副本,发生Failover时将自动拉起空分片,此时分片可用性得到恢复,但原有数据将会丢失。如果您希望在Failover场景下能够保留数据,需要在配置集群时在默认主副本的基础上添加至少一组从副本。

2、多机房容灾Redis支持同地域内的跨机房部署,以保障机房级别容灾;但是跨机房部署架构中,主实例故障Failover后,还需要多一次迁移恢复原来的部署拓扑(迁移的过程会有性能抖动)。因此,建议您根据业务需求选择合适的部署方式。此外,对于特别核心的业务建议申请两个不同机房的Redis集群,通过双写的形式满足更高的高可用需求。

1.3、正确设计和存储数据

1、规范对Key的命名:业务在设计Key的名称时,长度应控制在1024字节以内,过大的Key名称意味着更多的缓存空间占用。同时,禁止使用不可打印字符作为Key名称,避免会对后期缓存数据的维护、问题排查带来额外的负担。

2、避免存储大Value:为优化性能和避免数据倾斜问题,Redis应避免存储大Value(集合类型元素数量<5000,字符串类型<10KB)。大Value不仅导致分片数据量和流量不均衡,还直接影响访问性能,增加延迟和资源消耗,因此合理控制Value大小对于提升系统效率和稳定性至关重要。

3、设计业务逻辑避免引入热Key:热Key意味着业务流量会集中访问集群特定分片,导致单个分片压力过大,不能发挥集群多分片的优势。热key导致的单分片性能瓶颈,也无法通过扩容解决。(存在热Key风险的业务建议开启热Key缓存功能)。

4、合理设置Key过期时间:建议为每个Key设置适当的过期时间,以避免浪费缓存资源。同时,尽可能打散Key的过期时间,避免大量Key集中过期,从而降低对集群性能的影响。通过合理设置过期时间和分散过期时间,可以提高缓存的利用率,保持系统的性能和可用性。

5、选择合适的淘汰策略:创建JIMDB集群时结合业务场景选择合适的淘汰策略,如volatile-lru(设置了过期时间的Key按照lru进行逐出)、allkeys-lru(所有Key按照lru进行逐出)、noeviction(不淘汰数据,但写入会失败)等,确保高效利用有限资源,同时提高缓存命中率。

1.4、优化读写请求

1、避免过度复杂的命令:在执行复杂度为O(n)的命令(如HGETALL、SMEMBERS、LRANGE、DEL等)时,需要特别注意参数n的大小。如果n过大,将导致JIMDB服务阻塞,影响其他操作的执行和系统的性能。因此,合理控制n的大小,避免复杂度过高的操作,是保持JIMDB服务的稳定性和可用性的重要考虑因素。

2、合理使用异步/pipline:在异步操作或使用pipeline场景中,需要谨慎控制读操作的频率或单批次操作的Key数量。频繁的读操作、大批量操作可能导致缓存实例输出缓冲区的数据积压,进而触发OOM(Out of Memory)kill机制,造成数据丢失。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/578250.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Adobe Application Manager丢失或损坏 - 解决方案

前言 Adobe Application Manager&#xff08;简称AAM&#xff09;&#xff0c;是用来管理旧版Adobe软件的管理器&#xff0c;后来已经升级为Adobe Creative Cloud&#xff08;简称ACC&#xff09;。 使用Adobe系列软件时可能会报错提示需要使用Adobe Application Manager解决…

【Windows编程】期末复习题3

系列文章目录 期末复习题1 期末复习题2 文章目录 系列文章目录什么是事件驱动的程序执行过程&#xff1f;简要描述Windows的事件驱动程序模型。什么是动态链接库&#xff1f;其作用是什么&#xff1f;在Windows API程序设计中&#xff0c;资源的主要作用有哪些&#xff1f;Vis…

wifi驱动打开双模式

双模式 3.1 开启双模式 在Makefile添加EXTRA_CFLAGS -DCONFIG_CONCURRENT_MODE 重新编译&#xff08;make之后发现不正常工作&#xff0c;需要make clean清理一下&#xff09;。 再用sudo rmmod 8821cu.ko&#xff0c;重新启动。出现wlan1&#xff1a; 出现问题&#xff1…

助力打造清洁环境,基于轻量级DETR(DEtectionTRansformer)开发构建公共场景下垃圾堆放垃圾桶溢出检测识别系统

公共社区环境生活垃圾基本上是我们每个人每天几乎都无法避免的一个问题&#xff0c;公共环境下垃圾投放点都会有固定的值班时间&#xff0c;但是考虑到实际扔垃圾的无规律性&#xff0c;往往会出现在无人值守的时段内垃圾堆放垃圾桶溢出等问题&#xff0c;有些容易扩散的垃圾比…

2024年PMP考试新考纲-PMBOK第七版-项目绩效域真题解析

如何一次性通过PMP考试&#xff0c;取得3A等级的PMP证书&#xff1f;华研荟根据十多年的培训和辅导&#xff0c;以及数千名学员的建议是&#xff1a; 先把PMBOK第六版、第七版和敏捷实践指南的三本官方教材研读一遍&#xff08;如果觉得自己看书慢&#xff0c;可以看讲解视频&…

基于多反应堆的高并发服务器【C/C++/Reactor】(中)Dispatcher模块的实现思路和定义

&#xff08;四&#xff09;Dispatcher模块的实现思路 关于dispatcher&#xff0c;它应该是反应堆模型里边的核心组成部分&#xff0c;因为如果说这个反应堆模型里边有事件需要处理&#xff0c;或者说有事件需要检测&#xff0c;那么是需要通过这个poll、epoll 或者 select来完…

Spring Boot3 Web开发技术

前期回顾 springboot项目常见的配置文件类型有哪些&#xff1f;哪种类型的优先级最高 yml properties yaml 读取配置文件里的数据用什么注解&#xff1f; value restful风格 RESTful 风格与传统的 HTTP 请求方式相比&#xff0c;更加简洁&#xff0c;安全&#xff0c;能隐…

有赞微商城集成CRM:无代码电商平台优化用户运营

有赞微商城与无代码开发的完美结合 在数字化转型的浪潮中&#xff0c;无代码开发是商家极力追求的目标&#xff0c;它能够让非技术人员也能轻松地实现软件集成和数据流转。有赞微商城的出现&#xff0c;就是为了响应这一需求。通过无需复杂编程即可实现的API集成&#xff0c;商…

Kind创建k8s - JAVA操作控制

kind 简介kind 架构安装 Kind (必备工具)docker官网kubectl官网kind官网校验安装结果 关于kind 命令 安装一个集群查看当前 Kubernetes 集群中的节点信息。查看当前命名空间下中的Pod&#xff08;容器实例&#xff09;的信息。使用 kind create cluster 安装&#xff0c;关于安…

MYSQL一一函数一一流程函数

咱今天讲的是MySQL函数中的流程函数&#xff0c;会有3小题和一个综合案例帮助大家理解 流程函数是很常用的一类函数&#xff0c;可以在SQL语句中实现条件筛选&#xff0c;从而提高语句的效率 小题&#xff1a; ①if语句&#xff1a; select if(flash,ok,error); //如果…

Java之Atomic 原子类总结

Java之Atomic 原子类总结 Atomic 原子类介绍 Atomic 翻译成中文是原子的意思。在化学上&#xff0c;我们知道原子是构成一般物质的最小单位&#xff0c;在化学反应中是不可分割的。在我们这里 Atomic 是指一个操作是不可中断的。即使是在多个线程一起执行的时候&#xff0c;一…

【Java】你掌握了多线程吗?

【文末送书】今天推荐一本Java多线程编程领域新书《一本书讲透Java线程》 摘要 互联网的每一个角落&#xff0c;无论是大型电商平台的秒杀活动&#xff0c;社交平台的实时消息推送&#xff0c;还是在线视频平台的流量洪峰&#xff0c;背后都离不开多线程技术的支持。在数字化转…

FPGA-ZYNQ-7000 SoC在嵌入式系统中的优势

FPGA-ZYNQ-7000 SoC在嵌入式系统中的优势 本章节主要参考书籍《Xilinx Zynq-7000 嵌入式系统设计与实现 基于ARM Cortex-A9双核处理器和Vivado的设计方法 (何宾&#xff0c;张艳辉编著&#xff09;》 本章节主要讲述FPGA-ZYNQ-7000 SoC在嵌入式系统中的优势&#xff0c;学习笔…

LeetCode刷题--- 优美的排列

个人主页&#xff1a;元清加油_【C】,【C语言】,【数据结构与算法】-CSDN博客元清加油_【C】,【C语言】,【数据结构与算法】-CSDN博客 个人专栏 力扣递归算法题 http://t.csdnimg.cn/yUl2I 【C】 http://t.csdnimg.cn/6AbpV 数据结构与算法 ​​​​​​http://t.cs…

java web中 EL表达式的相关案例:

java web中 EL表达式的相关案例&#xff1a; <% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%><%String abc"ABC";String xyz"XYZ";//原因是没有把abc放到作用域里pageContext.…

UGUI Panel的显示和隐藏优化

unity UI如何开启&#xff08;显示&#xff09;或者关闭&#xff08;隐藏&#xff09;Panel界面&#xff0c;相信大家都是知道的&#xff0c;但是如何做最好呢&#xff1f; 可能大家一般开启/关闭界面的方法就是直接SetActive吧。这样做通常是可以的&#xff0c;简答快速地解决…

开发环境和生产环境的区别

软件开发环境(Software Development Environment&#xff0c;SDE)是指在基本硬件和宿主软件的基础上&#xff0c;为支持系统软件和应用软件的工程化开发和维护而使用的一组软件&#xff0c;简称SDE。它由软件工具和环境集成机制构成&#xff0c;前者用以支持软件开发的相关过程…

【MATLAB】 RGB和YCbCr互转

前言 在视频、图像处理领域经常会遇到不同色域图像的转换&#xff0c;比如RGB、YUV、YCbCr色域间的转换&#xff0c;这里提供一组转换公式&#xff0c;供大家参考。 色彩模型 RGB RGB色彩模型是一种用于表示数字图像的颜色空间&#xff0c;其中"RGB"代表红色&…

排序算法--------计数排序

作者前言 &#x1f382; ✨✨✨✨✨✨&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f382; ​&#x1f382; 作者介绍&#xff1a; &#x1f382;&#x1f382; &#x1f382; &#x1f389;&#x1f389;&#x1f389…

记录每日LeetCode 1276.不浪费原料的汉堡制作方案 Java实现

题目描述&#xff1a; 圣诞活动预热开始啦&#xff0c;汉堡店推出了全新的汉堡套餐。为了避免浪费原料&#xff0c;请你帮他们制定合适的制作计划。 给你两个整数 tomatoSlices 和 cheeseSlices&#xff0c;分别表示番茄片和奶酪片的数目。不同汉堡的原料搭配如下&#xff1a…