返回顶部
首页 > 资讯 > 数据库 >Redis进行相关优化详解
  • 322
分享到

Redis进行相关优化详解

Redis进行相关优化Redis优化 2022-08-08 12:08:27 322人浏览 安东尼
摘要

目录前言内存维度控制key的长度避免存储bigkey如何查询bigkey选择合适的数据类型采用高效的序列化和压缩方法设置Redis最大内存和淘汰策略控制Redis实例的大小定时清除内存碎片性能维度禁止使用KEYS、FLU

前言

Redis在项目中进行广泛使用,那么在日常的开发过程中,我们在使用Redis的过程中需要注意那些呢?本文将从三个维度来讲解如何进行Redis的优化。

内存维度

控制key的长度

key的一般都是采用字符串,而字符串的底层数据结构为SDS,SDS 结构中会包含字符串长度、分配空间大小等元数据信息,当key字符串的长度增加时,SDS中的元数据也会占用更多内存空间,为了减少key的占用空间,我们可用根据业务名来使用相应的英文缩写来表示。例如user用u表示,message 用m来表示。

避免存储bigkey

我们既要注意key的长度,同时也需要关注value的大小,Redis是使用单线程读写数据,bigkey 的读写操作会阻塞线程,降低Redis的处理效率。

如何查询bigkey

我们可以通过--bigkey的命令来查看Redis中所占用的bigkey的信息,具体的命令如下:

redis-cli -h 127.0.0.1 -p 6379 -a 'xxx' --bigkeys

Redis进行相关优化详解

从上述图所示,我们可以查看到Redis中的key占用了32098个bytes,需要进行相关优化的。

建议:

  • 如果key为string类型,建议value的存放值的大小为10KB左右。
  • 如果key为List/Hash/Set/ZSet类型,建议存放元素的的数量控制在1万以下。

选择合适的数据类型

Redis提供了丰富的数据类型,对于存放的内存也做了相关优化。关乎数据结果的相关知识,可以参考之前的文章。

例如:String和set在存储int数据时,会采用整数编码存储。Hash、ZSet在元素数量比较少时,会采用压缩列表(ziplist)存储,在存储比较多的数据时,才会转换为哈希表和跳表。

采用高效的序列化和压缩方法

Redis中的字符串都是使用二进制安全的字节数组来保存的,所以我们可以把业务的序列化成二进制写入Redis,但是采用不同的序列化,所占用的空间大少不一样。比如使用protostuff的序列化比Java内置的序列化效率更高,占用空间更少。针对JSON和XML数据格式的,可以采用gzip或者snappy算法对数据进行压缩存储,从而节省空间。

设置Redis最大内存和淘汰策略

我们根据业务的数据量提前预估内存大小,从而避免Redis的内存持续膨胀,导致占用过多资源。

关于如何设置淘汰策略,需要集合实际的业务特性来选择:

  • volatile-lru / allkeys-lru:优先保留最近访问过的数据
  • volatile-lfu / allkeys-lfu:优先保留访问次数最频繁的数据
  • volatile-ttl :优先淘汰即将过期的数据
  • volatile-random / allkeys-random:随机淘汰数据

控制Redis实例的大小

Redis单实例的内存大小建议设置在2~6GB之间。因为无论是RDB快照,还是主从集群进行数据同步,都能很快完成,不会阻塞正常请求的处理。

定时清除内存碎片

频繁的新增修改会导致内存碎片的增多,因此需要及时清理内存碎片。

Redis提供了Info memory命令可以查看内存使用信息,具体如下:

Redis进行相关优化详解

说明:

  • used_memory_RSS是操作系统实际分配给 Redis的物理内存空间。
  • used_memory 是 Redis 为了保存数据实际申请使用的空间。
  • mem_fragmentation_ratio=used_memory_rss/ used_memory
  • mem_fragmentation_ratio 大于1但小于1.5。这种情况是合理的。
  • mem_fragmentation_ratio大于1.5 这表明内存碎片率已经超过了50%。一般情况下,这个时候,我们就需要采取一些措施来降低内存碎片率了。具体的内存清理措施,将在后续的文章中进行讲解。

性能维度

禁止使用KEYS、FLUSHALL、FLUSHDB命令

  • KEYS 按照key内容进行匹配,返回符合匹配条件的键值对,该命令需要对Redis的全局哈希表进行全表扫描,严重阻塞 Redis主线程。
  • FLUSHALL 删除Redis实例上的所有数据,如果数据量很大,会严重阻塞Redis主线程。
  • FLUSHDB,删除当前数据库中的数据,如果数据量很大,会阻塞Redis主线程。

优化建议

我们需要在线上要禁用这些命令。具体的做法是,管理员采用rename-command命令在配置文件中对这些命令进行重命名,让客户端无法使用这些命令。

慎用全量操作的命令

对于集合类型的来说,在未清楚集合数据大小的情况下,慎用查询集合中的全量数据,例如Hash的HetALL、Set的SMEMBERS命令、LRANGE key 0 -1 或者ZRANGE key 0 -1等命令,因为这些命令会对Hash或者Set类型的底层数据进行全量扫描,当集合数据量比较大时,会阻塞Redis的主线程。

优化建议:

当元素数据量较多时,可以用SSCAN、HSCAN 命令分批返回集合中的数据,减少对主线程的阻塞。

慎用复杂度过高命令

Redis执行复杂度过高的命令,会消耗更多的 CPU 资源,导致主线程中的其它请求只能等待。常见的复杂命令如下:SORT、SINTER、SINTERSTORE、ZUNIONSTORE、ZINTERSTORE 等聚合类命令。

优化建议:

当需要执行排序、交集、并集操作时,可以在客户端完成,避免让Redis进行过多计算,从而影响Redis性能。

设置合适的过期时间

Redis通常用于保存热数据。热数据一般都有使用的时效性。所以,在数据保存时,根据业务使用数据的时长,合理的设置数据的过期时间。否则写入Redis的数据会一直占用内存,如果数据持续增增长,会达到机器的内存上限,造成内存溢出,导致服务崩溃。

采用批量命令代替个命令

当我们需要一次性操作多个key时,可以使用批量命令来处理,批量命令可以减少客户端与服务端的来回网络IO次数。

  • String或者Hash类型可以使用 MGET/MSET替代 GET/SET,HMGET/HMSET替代HGET/HSET
  • 其它数据类型使用Pipeline命令,一次性打包发送多个命令到服务端执行。

Pipeline具体使用:

redisTemplate.executePipelined(new RedisCallback<String>() {
            @Override
            public String doInRedis(RedisConnection connection) throws DataAccessException {
                for (int i = 0; i < 5; i++) 
                {
                    connection.set(("test:" + i).getBytes(), "test".getBytes());
                }
                return null;
            }
        });

高可用维度

按照业务部署不同的实例

不同的业务线来部署 Redis 实例,这样当其中一个实例发生故障时,不会影响到其它业务。

避免单点问题

业务上根据实际情况采用主从、哨兵、集群方案,避免单点故障,影响业务的正常使用。

合理的设置相关参数

针对主从环境,我们需要合理设置相关参数,具体内容如下:

  • 合理的设置repl-backlog参数:如果repl-backlog设置过小,当写流量比较大的场景下,主从复制中断可能会引发全量复制数据的风险。
  • 合理设置slave client-output-buffer-limit:当从库复制发生问题时,过小的 buffer会导致从库缓冲区溢出,从而导致复制中断。

总结

本文对于Redis的如何优化从内存、性能、高可用等三个维度进行了详细的讲解,如有大家还有什么优化建议欢迎提出,大家共同学习,共同进步。

到此这篇关于Redis进行相关优化的文章就介绍到这了,更多相关Redis优化内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: Redis进行相关优化详解

本文链接: https://lsjlt.com/news/33521.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Redis进行相关优化详解
    目录前言内存维度控制key的长度避免存储bigkey如何查询bigkey选择合适的数据类型采用高效的序列化和压缩方法设置Redis最大内存和淘汰策略控制Redis实例的大小定时清除内存碎片性能维度禁止使用KEYS、FLU...
    99+
    2022-08-08
    Redis进行相关优化 Redis优化
  • Redis集群的相关详解
    注意!要求使用的都是redis3.0以上的版本,因为3.0以上增加了redis集群的功能。 1.redis介绍 1.1什么是redis Redis是用C语言开发的一个开源的高性能键值对(key-value)...
    99+
    2024-04-02
  • 如何对Redis进行性能优化
    对Redis进行性能优化可以从以下几个方面入手: 配置优化:调整Redis的配置参数以达到更好的性能表现,如增加内存大小、调整最...
    99+
    2024-04-02
  • python进行相关性分析并绘制散点图详解
    目录 需要用到的库数据读取总结近期,有小伙伴问我关于怎么使用python进行散点图的绘制,这个东西很简单,但是怎么讲相关性的值标注在图形上略显麻烦,因此,在这里记录一下,将...
    99+
    2024-04-02
  • 详解Python进行数据相关性分析的三种方式
    目录相关性实现NumPy 相关性计算SciPy 相关性计算Pandas 相关性计算线性相关实现线性回归:SciPy 实现等级相关排名:SciPy 实现等级相关性:NumPy 和 Sc...
    99+
    2024-04-02
  • Java使用Redis及其优化详解
    目录前言开启远程连接Jedis连接Redis封装Jedis进行操作前言 所有坚韧不拔的努力迟早会取得报酬的。—— 安格尔 开启远程连接 Redis默认是不支持远程连接的,这里需要手动...
    99+
    2024-04-02
  • Unity项目优化相关技巧
    目录一、简单优化二、优化进阶四、代码相关优化一、简单优化 1.图片纹理大小尽量为2的幂次方(比如128,512,1024等等),以便unity对其进行优化。 2.将多个小图片纹理合并...
    99+
    2024-04-02
  • 使用SPSS进行相关性分析的相关步骤
    ...
    99+
    2016-11-12
    使用SPSS进行相关性分析的相关步骤
  • redis持久化相关参数有哪些
    这篇文章主要讲解了“redis持久化相关参数有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“redis持久化相关参数有哪些”吧!redis查看持久化信息...
    99+
    2024-04-02
  • Redis缓存空间优化实践详解
    目录导读场景设定常规做法改进1-去掉属性名改进2-使用更好的序列化工具改进3-优化数据类型改进4-考虑ZIP压缩最终落地场景延伸导读 缓存Redis,是我们最常用的服务,其适用场景广泛,被大量应用到各业务场景中。也正因如...
    99+
    2023-04-20
    Redis缓存空间优化实践 Redis缓存空间优化 Redis缓存空间
  • redis如何进行序列化
    redis如何进行序列化?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。序列化最终的目的是为了对象可以跨平台存储,和进行网络传输。而我们进行...
    99+
    2024-04-02
  • redis如何进行持久化
    小编给大家分享一下redis如何进行持久化,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1、redis简介REmote DIctionary Server(Redis) 是一个由Salva...
    99+
    2024-04-02
  • MySQL如何进行优化
    这篇文章主要讲解了“MySQL如何进行优化”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL如何进行优化”吧! 案例背景案例分析MySQL ...
    99+
    2024-04-02
  • 如何进行SEO优化
    这篇文章将为大家详细讲解有关如何进行SEO优化,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。SEO方案包括:1、网站SEO诊断先要给网站进行一个系统的SEO诊断,看看这个网站目前的优化情况到底是什么情况的...
    99+
    2023-06-10
  • sql如何进行优化
    如何优化 sql 查询 优化 SQL 查询的步骤: 1. 分析查询 找出需要优化的高耗时查询。 使用 EXPLAIN 命令来查看查询执行计划。 识别查询中的瓶颈,例如表扫描、索引扫描或...
    99+
    2024-06-21
  • JavaWebMaven详解相关配置
    目录1.Maven项目架构管理工具2.下载安装Maven3.配置环境4.阿里云镜像5.本地仓库6.在IDEA中使用Maven7.创建一个普通的Maven项目8.idea中标记文件夹功...
    99+
    2024-04-02
  • APAP ALV进阶写法及优化详解
    目录先导流程搭建流程讲解INITIALIZATION.at SELECTION-SCREEN!START-OF-SELECTIONEnd-OF-SELECTION&...
    99+
    2024-04-02
  • 怎样用Python进行相关性分析
    今天就跟大家聊聊有关怎样用Python进行相关性分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.相关和因果是一回事吗相关性不等于因果。用x1和x2作为两个变量进行解释,相关意味...
    99+
    2023-06-16
  • 网站优化中如何进行关键词的筛选
    本篇文章给大家分享的是有关网站优化中如何进行关键词的筛选,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。关键词是我...
    99+
    2024-04-02
  • 怎么对进行SpringBoot优化
    这期内容当中小编将会给大家带来有关怎么对进行SpringBoot优化,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spri...
    99+
    2023-05-31
    springboot bo
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作