我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Redis键值设计使用总结

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Redis键值设计使用总结

前言

对redis的使用,想必做过后端开发的同学都不陌生,redis为key/value非关系型数据库,使用起来简单高效,支持的数据类型也比较丰富,几乎在日常开发中没有不涉及的;

但如果对redis使用比较深入的话,还需要综合考虑多方面的因素,比如使用redis时如何兼具高效与性能,如何设计合理的key以达到存取时最高效等等,这都是应该考虑的,下面结合redis中一个比较简单但也容易的问题,关于redis的键值设计做一个全面的探讨;

Redis使用中不规范的现象

  • Redis 存储的key命名不规范,比较随意;
  • Redis 被当成存储库使用,存在数据丢失风险,且无重新加载方案;
  • Redis 缓存key,未设置过期时间, 缓存低频数据占用大量内存, 进而导致服务崩溃;
  • Redis 缓存大量big key, 应用获取时会占用大量网络带宽,删除也容易造成阻塞;
  • Redis 客户端使用不当,导致其它客户端连接timeout, 原因可能客户端密码错误,且没有使用连接池,大量连接重试导致系统端口资源耗光;
  • Redis 客户端命令使用不当,导致大量的慢查询,影响其它应用业务,比如在业务高峰期时使用 keys* 或flushall 这样的命令;

Redis 使用业务场景推荐与建议

  • 高并发场景:热点数据缓存, 可提升系统整体响应速度,降低数据库IO压力 ;
  • 限时场景:利用Redis expire命令设置session过期和续期、手机验证码等;
  • 排行榜: 利用Redis list 和 sorted sets 数据结构能实现各种复杂的排行榜应用;
  • 数据集合操作:利用Redis list、set、sorted set, 方便进行数据计算, 如交集、并集、差集等;
  • 连续签到:可以利用redis的bitmap数据结构实现签到相关的业务;
  • 计数器:利用Redis incr、incrby命令实现api调用次数统计, api限流等场景;
  • 分布式锁:利用 Redis 的 setnx 功能来编写分布式的锁, 典型开源组件比如redisson;

如何设计出优雅的key

可以这么说,线上关于redis的性能优化这个问题上,不合理的key的设计经常是引发问题的根因,究其本质,就个人看到的情况来说,大多数同学在对redis使用过程中,对于key的设计几乎是没有什么概念的,因为大多数同学使用的场景就是 key/val ,对应的数据结构就是 字符串key/字符串val;

稍微对redis有更深入的了解的同学,在进行存储时,可能会知道 key的设计尽量短一点,中间最好有层次感,最好以 : 进行分割 ......

那么如何才能设计出比较优雅的key呢?下面结合小编实际使用中的经验以及踩过的坑,来具体谈谈;

一、遵循如下几个最佳实践约定

  1. 遵循基本格式:[业务名称]:[数据名]:[id];
  2. key的长度不超过44字节;
  3. 不要包含特殊字符;

关于上面几条建议,这样做有如下几点好处:

  • 可读性强,比如当我们设计这样的key结构, order:user:10,一眼看过去就知道这是关于用户订单相关的key;
  • 方便维护管理,不同的应用,或者不同的业务采用不同的前缀,在可视化客户端工具或者命令行中很方便进行key的查找定位;
  • 避免key冲突,避免在使用过程中多个人都用userId这样的值作为key引发的缓存key冲突;
  • 更节省内存: key是string类型,底层编码包含int、embstr和raw三种。embstr在小于44字节使用,采用连续内存空间,内存占用更小;

推荐值:

  • 单个key的value小于10KB;
  • 对于集合类型的key,建议元素数量小于1000;

二、尽量避免bigkey

1、什么是bigkey呢

BigKey通常以Key的大小和Key中成员的数量来综合判定,例如:

  • Key本身的数据量过大:一个String类型的Key,它的值为5 MB;
  • Key中的成员数过多:一个ZSET类型的Key,它的成员数量为10,000个;
  • Key中成员的数据量过大:一个Hash类型的Key,它的成员数量虽然只有1,000个但这些成员的Value(值)总大小为100 MB;

2、BigKey的危害

网络阻塞

  • 对BigKey执行读请求时,少量的QPS就可能导致带宽使用率被占满,导致Redis实例,乃至所在物理机变慢;

数据倾斜

  • BigKey所在的Redis实例内存使用率远超其他实例,无法使数据分片的内存资源达到均衡;

Redis阻塞

  • 对元素较多的hash、list、zset等做运算会耗时较旧,使主线程被阻塞;

CPU压力

  • 对BigKey的数据序列化和反序列化会导致CPU的使用率飙升,影响Redis实例和本机其它应用;

3、如何发现BigKey

在安装的机器上执行 redis-cli --bigkeys命令

  • 利用redis-cli提供的--bigkeys参数,可以遍历分析所有key,并返回Key的整体统计信息与每个数据的Top1的big key;

通过scan扫描

  • 编写程序,利用scan扫描Redis中的所有key,利用strlen、hlen等命令判断key的长度(此处不建议使用MEMORY USAGE);

使用第三方工具

  • 利用第三方工具,如 Redis-Rdb-Tools 分析RDB快照文件,全面分析内存使用情况;

使用网络监控

  • 自定义工具,监控进出Redis的网络数据,超出预警值时主动告警;

三、使用恰当的数据类型

正如上面所说,很多初次使用redis的同学,对于很多业务场景,都是一个key/val的简单的结构搞定,而不会深入思考这样做是否合理,或者说这样做以后会不会引发相关的性能方面的问题;

对于这个问题,从根本上来说,需要深入了解并掌握redis的常用的数据类型,在这个基础上,才能针对不同的业务场景,设计出高效的存储存储结构数据;

让我们思考一下,如何缓存用户对象列表这样的数据呢?

  • 方案1:key为usrId,value为对象的序列化字符串,数据结构类似下面这样; 

优点:存取方便,简单粗暴,存取时只需要做下json和对象的互转即可;

缺点:数据耦合,不够灵活,一旦对象新增了字段或删减了字段,缓存重建的成本非常大;

  • 方案2:使用一个list结构,缓存用户ID列表,数据结构如下;

优点:对内存的占用小,操作高效;

缺点:获取到val之后,需要进一步查库才能得到完整的对象;

方案3:使用hash结构,缓存对象,数据如下所示;

优点:底层使用ziplist,空间占用小,可以灵活访问对象的任意字段;

缺点:编码上相对复杂;

Redis 缓存在实际应用中的使用建议

  • 【推荐】对缓存进行预热。在访问数据前,应先对缓存进行预热,避免大量请求直接进入数据存储层;应根据业务情况划分合适的冷热数据,对热点数据进行预热。如许可授权信息, apikey等;
  • 【推荐】配合使用本地缓存。使用本地缓存能更稳定、更快速地访问到数据,但在分布式架构下,要慎用本地缓存,避免造成服务器节点带状态。同时由于本地缓存直接占用应用服务器的资源,要避免过度占用资源导致应用节点崩溃;
  • 【推荐】缓存变更策略,应先更新数据库,再更新缓存;
  • 【推荐】一次业务调用需要访问多次redis服务端,可采用pipleline或其它批量操作方式;
  • 【推荐】大List,Set,Hash,存储的数量巨大。获得大量元素时延迟较大阻塞其他命令.建议切割成多个小的list,set,hash;

使用业务规范

不管是redis,还是其他开发中使用到的中间件,具体到开发使用时,最好都应该提前制定出一套合理的规范,这个规范应该是大多数开发人员认可并在实践中得到检验,且能有效规避一些问题的,一旦指定为规范,应该成为指导内部开发人员日常的规则,这里提如下几点:

  • Redis 应该定位为缓存数据, 不可用于存储大规模数据(不可替代数据库);
  • Redis 适合读多写少场景,如存在高频写入,低频查询场景,则不推荐使用;
  • 在不确定key的存活时间时,最好设置过期时间,控制 key 的生命周期;
  • 应该考虑冷热数据分离,对于查询, 高频次业务查询走Redis,低频查询考虑走数据库;
  • Redis 有数据丢失风险,程序处理数据时,应该考虑数据丢失后能自动从数据库加载并缓存到Redis;
  • 谨慎使用O(N)命令, 如list, set, hash 数据结构操作时, hgetall、lrange、smembers、zrange等并非不能使用,优先考虑使用 hscan、sscan、zscan 代替。

以上就是Redis 键值设计使用总结的详细内容,更多关于Redis 键值设计的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Redis键值设计使用总结

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Redis 键值设计使用总结

目录前言Redis使用中不规范的现象Redis 使用业务场景推荐与建议如何设计出优雅的key一、遵循如下几个最佳实践约定二、尽量避免bigkey三、使用恰当的数据类型Redis 缓存在实际应用中的使用建议使用业务规范前言对redis的使用
2023-04-07

Redis键值设计使用总结

这篇文章主要介绍了Redis键值设计的使用总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-14

Redis键值设计使用的方法是什么

这篇文章主要介绍了Redis键值设计使用的方法是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Redis键值设计使用的方法是什么文章都会有所收获,下面我们一起来看看吧。Redis使用中不规范的现象Redis
2023-07-05

Redis键值设计的实践

目录1 优雅的key结构2 拒绝BigKey2.1 判断BigKey2.2 BigKey的危害2.3 如何发现BigKey2.4 如何删除BigKey3 恰当的数据类型3.1 存储对象3.2 Hash优化在Redis中,良好的键值设计可以达
2023-01-30

MySQL中的常用树形结构设计总结

目录常用树形结构设计总结1. 递归表2.路径枚举3.数据与关系分开存mysql树形结构(多级菜单)查询设计方案三级查询(层级固定,层级数少)多级查询(层级不固定/层级很深)总结常用树形结构设计总结开发中,经常会遇到树形结构的设计,所谓的树
2023-03-03

PHP 企业级应用架构与设计要点总结

确定企业级 php 应用程序的关键架构设计原则:分层架构松散耦合单一职责原则工厂模式存储库模式服务层模式PHP 企业级应用架构与设计要点总结随着业务规模和复杂度的不断增长,设计企业级的 PHP 应用程序至关重要。本文概述了关键的架构和设计
PHP 企业级应用架构与设计要点总结
2024-05-08

如何在python中使用defaultdict计算键值的和

本篇文章给大家分享的是有关如何在python中使用defaultdict计算键值的和,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。python可以做什么Python是一种编程语
2023-06-14

MySql数据库日常设计和使用需要注意的几点总结

a,UTF-8的字符集是⼀一个汉字3个字节:varchar(255) UTF-8 255*3=765字节     b,禁⽌在表中建立预留字段     c,尽量避免加⼊外键约束,因为外键写入的时候会降低存储效率,但要给这些关联字段加索引
MySql数据库日常设计和使用需要注意的几点总结
2021-02-15

怎么在python中使用defaultdict计算键值的和

这篇文章将为大家详细讲解有关怎么在python中使用defaultdict计算键值的和,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python可以做什么Python是一种编程语言,内置了许
2023-06-14

js获取对象属性值的两种方法使用总结

这篇文章主要给大家介绍了关于js获取对象属性值的两种方法使用,分别是通过.获取和通过[]获取这两种方法,文中介绍了详细的方法和不同点,需要的朋友可以参考下
2023-05-18

如何使用Redis和Perl开发简单键值存储功能

如何使用Redis和Perl开发简单键值存储功能引言:Redis是一个开源的内存数据结构存储系统,它可以用于高效地存储和访问数据。而Perl是一种高级的脚本编程语言,它具有丰富的文本处理能力和便捷的模块集成方式。本文将介绍如何使用Redis
2023-10-22

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录