返回顶部
首页 > 资讯 > 数据库 >Redis热点 Key 问题发现与5种解决方案是什么
  • 665
分享到

Redis热点 Key 问题发现与5种解决方案是什么

2024-04-02 19:04:59 665人浏览 独家记忆
摘要

本篇文章给大家分享的是有关Redis热点 Key 问题发现与5种解决方案是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。热点问题产生的原因

本篇文章给大家分享的是有关Redis热点 Key 问题发现与5种解决方案是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

热点问题产生的原因大致有以下两种

1、用户消费的数据远大于生产的数据(热卖商品、热点新闻、热点评论、明星直播)。

在日常工作生活中一些突发的的事件,例如:双十一期间某些热门商品的降价促销,当这其中的某一件商品被数万次点击浏览或者购买时,会形成一个较大的需求量,这种情况下就会造成热点问题。

同理,被大量刊发、浏览的热点新闻、热点评论、明星直播等,这些典型的读多写少的场景也会产生热点问题。

2、请求分片集中,超过单 Server 的性能极限。

在服务端读数据进行访问时,往往会对数据进行分片切分,此过程中会在某一主机 Server 上对相应的 Key 进行访问,当访问超过 Server 极限时,就会导致热点 Key 问题的产生。

热点问题的危害

Redis热点 Key 问题发现与5种解决方案是什么

  • 1、流量集中,达到物理网卡上限。 

  • 2、请求过多,缓存分片服务被打垮。

  • 3、DB 击穿,引起业务雪崩。

如前文讲到的,当某一热点 Key 的请求在某一主机上超过该主机网卡上限时,由于流量的过度集中,会导致服务器中其它服务无法进行。

如果热点过于集中,热点 Key 的缓存过多,超过目前的缓存容量时,就会导致缓存分片服务被打垮现象的产生。

当缓存服务崩溃后,此时再有请求产生,会缓存到后台 DB 上,由于DB 本身性能较弱,在面临大请求时很容易发生请求穿透现象,会进一步导致雪崩现象,严重影响设备的性能。

解决方案

通常的解决方案主要集中在对客户端和 Server 端进行相应的改造。

1、服务端缓存方案

Redis热点 Key 问题发现与5种解决方案是什么

首先 Client 会将请求发送至 Server 上,而 Server 又是一个多线程的服务,本地就具有一个基于 Cache LRU 策略的缓存空间。

当 Server 本身就拥堵时,Server 不会将请求进一步发送给 DB 而是直接返回,只有当 Server 本身畅通时才会将 Client 请求发送至 DB,并且将该数据重新写入到缓存中。

此时就完成了缓存的访问跟重建。

但该方案也存在以下问题:

  • 1、缓存失效,多线程构建缓存问题 

  • 2、缓存丢失,缓存构建问题 

  • 3、脏读问题

2、使用 Memcache、Redis 方案

Redis热点 Key 问题发现与5种解决方案是什么

该方案通过在客户端单独部署缓存的方式来解决热点 Key 问题。

使用过程中 Client 首先访问服务层,再对同一主机上的缓存层进行访问。

该种解决方案具有就近访问、速度快、没有带宽限制的优点,但是同时也存在以下问题。

  • 1、内存资源浪费 

  • 2、脏读问题

3、使用本地缓存方案

使用本地缓存则存在以下问题:

  • 1、需要提前获知热点 

  • 2、缓存容量有限 

  • 3、不一致性时间增长 

  • 4、热点 Key 遗漏

传统的热点解决方案都存在各种各样的问题,那么究竟该如何解决热点问题呢?

4、读写分离方案解决热读

Redis热点 Key 问题发现与5种解决方案是什么

架构中各节点的作用如下:

  • 1、SLB 层做负载均衡 

  • 2、Proxy 层做读写分离自动路由 

  • 3、Master 负责写请求 

  • 4、ReadOnly 节点负责读请求 

  • 5、Slave 节点和 Master 节点做高可用

实际过程中 Client 将请求传到 SLB,SLB 又将其分发至多个 Proxy 内,通过 Proxy 对请求的识别,将其进行分类发送。

例如,将同为 Write 的请求发送到 Master 模块内,而将 Read 的请求发送至 ReadOnly 模块。

而模块中的只读节点可以进一步扩充,从而有效解决热点读的问题。

读写分离同时具有可以灵活扩容读热点能力、可以存储大量热点Key、对客户端友好等优点。

5、热点数据解决方案

Redis热点 Key 问题发现与5种解决方案是什么

该方案通过主动发现热点并对其进行存储来解决热点 Key 的问题。

首先 Client 也会访问 SLB,并且通过 SLB 将各种请求分发至 Proxy 中,Proxy 会按照基于路由的方式将请求转发至后端的 Redis 中。

在热点 key 的解决上是采用在服务端增加缓存的方式进行。

具体来说就是在 Proxy 上增加本地缓存,本地缓存采用 LRU 算法来缓存热点数据,后端 db 节点增加热点数据计算模块来返回热点数据。

Proxy 架构的主要有以下优点:

  • 1、Proxy 本地缓存热点,读能力可水平扩展 

  • 2、DB 节点定时计算热点数据集合 

  • 3、DB 反馈 Proxy 热点数据 

  • 4、对客户端完全透明,不需做任何兼容

热点 key 处理

热点数据的读取

Redis热点 Key 问题发现与5种解决方案是什么

在热点 Key 的处理上主要分为写入跟读取两种形式,在数据写入过程当 SLB 收到数据 K1 并将其通过某一个 Proxy 写入一个 Redis,完成数据的写入。

假若经过后端热点模块计算发现 K1 成为热点 key 后, Proxy 会将该热点进行缓存,当下次客户端再进行访问 K1 时,可以不经 Redis。

最后由于 proxy 是可以水平扩充的,因此可以任意增强热点数据的访问能力。

热点数据的发现

Redis热点 Key 问题发现与5种解决方案是什么

对于 db 上热点数据的发现,首先会在一个周期内对 Key 进行请求统计,在达到请求量级后会对热点 Key 进行热点定位,并将所有的热点 Key 放入一个小的 LRU 链表内,在通过 Proxy 请求进行访问时,若 Redis 发现待访点是一个热点,就会进入一个反馈阶段,同时对该数据进行标记。

DB 计算热点时,主要运用的方法和优势有:

  • 1、基于统计阀值的热点统计 

  • 2、基于统计周期的热点统计 

  • 3、基于版本号实现的无需重置初值统计方法 

  • 4、DB 计算同时具有对性能影响极其微小、内存占用极其微小等优点

方案对比

通过上述对比分析可以看出,在解决热点 Key 上较传统方法相比都有较大的提高,无论是基于读写分离方案还是热点数据解决方案,在实际处理环境中都可以做灵活的水平能力扩充、都对客户端透明、都有一定的数据不一致性。

此外读写分离模式可以存储更大量的热点数据,而基于 Proxy 的模式有成本上的优势。

您可能感兴趣的文档:

--结束END--

本文标题: Redis热点 Key 问题发现与5种解决方案是什么

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

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

猜你喜欢
  • Redis热点 Key 问题发现与5种解决方案是什么
    本篇文章给大家分享的是有关Redis热点 Key 问题发现与5种解决方案是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。热点问题产生的原因...
    99+
    2024-04-02
  • Redis什么是热Key问题以及如何解决热Key问题
    目录一、什么是热Key?二、热Key产生的原因?三、热点Key的危害?四、如何识别热点Key?五、如何解决热Key问题?一、什么是热Key? 在Redis中,我们把访问频率高的Key,称为热Key。 比如突然又几十万的请...
    99+
    2022-11-18
    Redis热Key 解决热Key问题 Redis什么是热Key
  • Redis中热点key存储问题怎么解决
    今天小编给大家分享一下Redis中热点key存储问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一...
    99+
    2024-04-02
  • Redis中什么是Big Key(大key)问题?如何解决Big Key问题?
    目录一、什么是Big Key二、Big Key产生的场景?三、Big Key的危害?四、如何识别Big Key?五、如何解决Big Key问题?补充知识:key设计总结一、什么是Big Key 通俗易懂的讲,Big Ke...
    99+
    2023-03-15
    redis big keys redis大key问题 redis大key优化
  • Redis中什么是Big Key(大key)问题?如何解决Big Key问题?
    目录一、什么是Big Key二、Big Key产生的场景?三、Big Key的危害?四、如何识别Big Key?五、如何解决Big Key问题?补充知识:key设计总结一、什么是Bi...
    99+
    2023-03-15
    redis big keys redis大key问题 redis大key优化
  • Redis中的BigKey问题排查与解决方法是什么
    这篇文章主要介绍“Redis中的BigKey问题排查与解决方法是什么”,在日常操作中,相信很多人在Redis中的BigKey问题排查与解决方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Redis中的...
    99+
    2023-07-05
  • Flex组件开发常见问题的解决方案是什么
    Flex组件开发常见问题的解决方案是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Flex组件开发总结如何监听键盘事件?<mx:TextAreaidm...
    99+
    2023-06-17
  • LeetCode中Java路径问题的解决方案是什么?
    LeetCode是一个著名的面试题库和算法题库,主要提供各种编程语言的算法题目,其中Java是其中一个主要支持的编程语言。在LeetCode中,路径问题是一个非常常见的问题,包括二叉树路径、图的路径、字符串路径等等,而这些问题的解决方案也非...
    99+
    2023-09-20
    path leetcode 响应
  • Flex跨域访问沙箱问题的解决方案是什么
    Flex跨域访问沙箱问题的解决方案是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。当Flex访问WebService服务时,在本地能够正常访问,当部署到we...
    99+
    2023-06-17
  • 微信小程序开发的三个问题和解决方案是什么
    微信小程序开发的三个问题和解决方案是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在微信公布小程序的文档和开发工具后,我们在第一时间进行了学习和体验,发现微信小程序的技...
    99+
    2023-06-04
  • 网站开发中网站空间常出现的三个问题及解决方案是什么
    网站开发中网站空间常出现的三个问题及解决方案是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。针对这个问题在这里为大家解决一下。网站空间呈现不能访问的状况应当怎么自我查看...
    99+
    2023-06-07
  • ASP路径和Laravel的打包问题:解决方案是什么?
    随着互联网技术的不断发展,越来越多的人开始使用ASP和Laravel来开发网站。不过,这两种技术在路径和打包方面存在一些问题,本文将介绍这些问题的解决方案。 ASP路径问题 在ASP开发中,路径问题是一个常见的难题。在ASP中,路径通常是...
    99+
    2023-07-29
    path 打包 laravel
  • 网站开发中外链出现的问题及解决方法是什么
    网站开发中外链出现的问题及解决方法是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。我负责的是一个b2b网站。姑且不说网站在站内建设方面存在的不足,针对网站半年以来,做外链的...
    99+
    2023-06-12
  • LeetCode 算法挑战中的容器并发问题:ASP.NET Core 的解决方案是什么?
    随着互联网的快速发展,各种应用程序的开发和部署也越来越快。然而,随之而来的是更多的容器并发问题。在LeetCode算法挑战中,我们常常会碰到这样的问题:如何在ASP.NET Core中解决容器并发问题? ASP.NET Core是一个跨平...
    99+
    2023-10-12
    leetcode 容器 并发
  • Linux服务器安全问题的解决方案是什么样的
    这期内容当中小编将会给大家带来有关Linux服务器安全问题的解决方案是什么样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。linux服务器有很多值得学习的地方,这里我们主要介绍linux服务器安全问题,...
    99+
    2023-06-17
  • Java框架和Linux:同步的问题和解决方案是什么?
    Java是一种流行的编程语言,被广泛应用于Web应用程序、企业级应用程序和移动应用程序。而Linux则是一个开源的操作系统,被广泛应用于服务器、桌面和嵌入式设备等领域。在这两个领域中,同步是一个非常重要的问题。本文将介绍Java框架和Li...
    99+
    2023-09-18
    框架 linux 同步
  • Puppet监控速查问题的原因及解决方案是什么
    Puppet监控速查问题的原因及解决方案是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Puppet是基于C/S架构的集中配置管理系统,基于自有描述性语言,可以实现对配置文...
    99+
    2023-06-05
  • CentOS8出现-bash乱码问题及解决方法是什么
    今天给大家介绍一下CentOS8出现-bash乱码问题及解决方法是什么。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。Linux系统中会因为没有安装中文语言包而...
    99+
    2023-06-28
  • 大数据分布式中常见问题的解决方案是什么
    大数据分布式中常见问题的解决方案是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1分布式中的常见问题解决方案下面是关于分布式系统中最常见的三种问题本部分内容包括:分布式...
    99+
    2023-06-19
  • ASP函数path同步的常见问题及解决方案是什么?
    在ASP开发中,我们经常会使用到path函数,它是用来获取当前脚本的物理路径的函数。但是,在使用path函数时,我们常常会遇到一些问题,比如路径同步不正确、路径分隔符错误等等。本文将为大家介绍path函数的常见问题及解决方案。 1.路径同...
    99+
    2023-09-30
    函数 path 同步
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作