iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Redis在项目中的应用场景是什么
  • 454
分享到

Redis在项目中的应用场景是什么

2024-04-02 19:04:59 454人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关Redis在项目中的应用场景是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。相信对于绝大多数程序员来说,redis中间件应该是大家非常熟悉

这篇文章将为大家详细讲解有关Redis项目中的应用场景是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

相信对于绝大多数程序员来说,redis中间件应该是大家非常熟悉的。但是对于工作中经常写业务代码的程序员来说,他们在实际工作中可能只是用到了set value、get value等操作,对于redis缺乏整体认识。

Redis是什么?

Redis是一个开源的底层使用C语言编写的key-value存储数据库。可用于缓存、事件发布订阅、高速队列等场景。而且支持丰富的数据类型:string(字符串)、hash(哈希)、list(列表)、set(无序集合)、zset(sorted set:有序集合)

Redis在项目中的应用场景

1、缓存数据

最常用,对经常需要查询且变动不是很频繁的数据 常称作热点数据。

2、消息队列

相当于消息订阅系统,比如ActiveMQRocketMQ。如果对数据有较高一致性要求时,还是建议使用MQ)

3、计数器

比如统计点击率、点赞率,redis具有原子性,可以避免并发问题

4、电商网站信息

大型电商平台初始化页面数据的缓存。比如去哪儿网购买机票的时候首页的价格和你点进去的价格会有差异。

5、热点数据

比如新闻网站实时热点、微博热搜等,需要频繁更新。总数据量比较大的时候直接从数据库查询会影响性能

给个爱的理由

在单节点服务器我们通常是这样的

Redis在项目中的应用场景是什么

随着企业的发展、业务的扩展。面对海量的数据,直接使用Mysql会导致性能下降,数据的读写也会非常慢。于是我们就可以搭配缓存来处理海量数据。

于是现在我们是这样的:

Redis在项目中的应用场景是什么

上图只是简述了缓存的作用,当数据继续增大我们需要利用主从复制技术来达到读写分离

数据库层直接与缓存进行交互,如果缓存中有数据直接返回客户端,如果没有才会从mysql中去查询。从而减小了数据库的压力,提升了效率。

平时发布了一款新手机,会有抢购活动。同一时间段,服务端会收到很多的下单请求。

我们需要使用redis的原子操作来实现这个“单线程”。首先我们把库存存在一个列表中,假设有10件库存,就往列表中push20个数,这个数没有实际意义,仅仅只是代表10件库存。抢购开始后,每到来一个用户,就从列表中pop一个数,表示用户抢购成功。当列表为空时,表示已经被抢光了。因为列表的pop操作是原子的,即使有很多用户同时到达,也是依次执行的

题外话:还有的抢购是直接在前端页面限制请求,这些请求直接被前端拦截,并没有到后端服务器

Redis为什么会这么快?

1、Redis是纯内存操作,需要的时候需要我们手动持久化到硬盘中

2、Redis是单线程,从而避开了多线程中上下文频繁切换的操作。

3、Redis数据结构简单、对数据的操作也比较简单

4、使用底层模型不同,它们之间底层实现方式以及与客户端之间通信的应用协议不一样,Redis直接自己构建了VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求

5、使用多路I/O复用模型,非阻塞I/O

多路I/O复用: I/O 多路复用技术是为了解决进程或线程阻塞到某个 I/O 系统调用而出现的技术,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪,就是这个文件描述符进行读写操作之前),能够通知程序进行相应的读写操作

学习视频分享:redis视频教程

Redis数据类型的应用场景

前面提到了Redis支持五种丰富的数据类型,那么在不同场景下我们该怎么选择呢?

String

字符串是最常用的数据类型,他能够存储任何类型的字符串,当然也包括二进制、JSON化的对象、甚至是base64编码之后的图片。在Redis中一个字符串最大的容量为512MB,可以说是无所不能了。

Hash

常用作存储结构化数据、比如论坛系统中可以用来存储用户的Id、昵称、头像、积分等信息。如果需要修改其中的信息,只需要通过Key取出Value进行反序列化修改某一项的值,再序列化存储到Redis中,Hash结构存储,由于Hash结构会在单个Hash元素在不足一定数量时进行压缩存储,所以可以大量节约内存。这一点在String结构里是不存在的。

List

List的实现为一个双向链表,即可以支持反向查找和遍历,更方便操作,不过带来了部分额外的内存开销,Redis 内部的很多实现,包括发送缓冲队列等也都是用的这个数据结构。另外,可以利用 lrange 命令,做基于 Redis 的分页功能,性能极佳,用户体验好。

Set

set 对外提供的功能与 list 类似是一个列表的功能,特殊之处在于 set 是可以自动排重的,当你需要存储一个列表数据,又不希望出现重复数据时,这个时候就可以选择使用set。

Sort Set

可以按照某个条件的权重进行排序,比如可以通过点击数做出排行榜的数据应用。

Redis缓存的数据一致性

真正意义上来讲数据库的数据和缓存的数据是不可能一致的,数据分为最终一直和强一致两类。如果业务中对数据的要求必须强一直那么就不能使用缓存。缓存能做的只能保证数据的最终一致性。

我们能做的只能是尽可能的保证数据的一致性。不管是先删库再删缓存 还是 先删缓存再删库,都可能出现数据不一致的情况,因为读和写操作是并发的,我们没办法保证他们的先后顺序。具体应对策略还是要根据业务需求来定,这里就不赘述了。

Redis的过期和内存淘汰

Redis存储数据时我们可以设置他的过期时间。但是这个key是怎么删除的呢?

一开始我认为是定时删除,后来发现并不是这样,因为如果定时删除,需要一个定时器来不断的负责监控这个key,虽然内存释放了,但是非常消耗cpu资源。

Redis过期删除采用的是定期删除,默认是每100ms检测一次,遇到过期的key则进行删除,这里的检测并不是顺序检测,而是随机检测。那这样会不会有漏网之鱼?显然Redis也考虑到了这一点,当我们去读/写一个已经过期的key时,会触发Redis的惰性删除策略,直接回干掉过期的key

内存淘汰是指用户存储的一部分key是可以被Redis自动的删除,从而会出现从缓存中查不到数据的情况。加入我们的服务器内存为2G、但是随着业务的发展缓存的数据已经超过2G了。但是这并不影响我们程序的运行,因为操作系统的可见内存并不受物理内存的限制。物理内存不够用没关系,计算机会从硬盘中划出一片空间来作为虚拟内存。这就是Redis设计两种应用场景的初衷:缓存、持久存储

缓存击穿

缓存只是为了缓解数据库压力而添加的一层保护层,当从缓存中查询不到我们需要的数据就要去数据库中查询了。如果被黑客利用,频繁去访问缓存中没有的数据,那么缓存就失去了存在的意义,瞬间所有请求的压力都落在了数据库上,这样会导致数据库连接异常。

解决方案:

1、后台设置定时任务,主动的去更新缓存数据。这种方案容易理解,但是当key比较分散的时候,操作起来还是比较复杂的

2、分级缓存。比如设置两层缓存保护层,1级缓存失效时间短,2级缓存失效时间长。有请求过来优先从1级缓存中去查找,如果在1级缓存中没有找到相应数据,则对该线程进行加,这个线程再从数据库中取到数据,更新至1级和2级缓存。其他线程则直接从2级线程中获取

3、提供一个拦截机制,内部维护一系列合法的key值。当请求的key不合法时,直接返回。

缓存雪崩

缓存雪崩就是指缓存由于某些原因(比如 宕机、cache服务挂了或者不响应)整体crash掉了,导致大量请求到达后端数据库,从而导致数据库崩溃,整个系统崩溃,发生灾难,也就是上面提到的缓存击穿。

Redis在项目中的应用场景是什么

如何避免雪崩:

1、给缓存加上一定区间内的随机生效时间,不同的key设置不同的失效时间,避免同一时间集体失效。

2、和缓存击穿解决方案类似,做二级缓存,原始缓存失效时从拷贝缓存中读取数据。

3、利用加锁或者队列方式避免过多请求同时对服务器进行读写操作。

结语:

Redis的性能极高,读的速度是110000次/s,写的速度是81000次/s,支持事务,支持备份,丰富的数据类型。

任何事情都是两面性,Redis也是有缺点的:

1、由于是内存数据库,所以单台机器存储的数据量是有限的,需要开发者提前预估,需要及时删除不需要的数据。

2、当修改Redis的数据之后需要将持久化到硬盘的数据重新加入到内容中,时间比较久,这个时候Redis是无法正常运行的。

关于“Redis在项目中的应用场景是什么”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: Redis在项目中的应用场景是什么

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

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

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • Redis在项目中的应用场景是什么
    这篇文章将为大家详细讲解有关Redis在项目中的应用场景是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。相信对于绝大多数程序员来说,redis中间件应该是大家非常熟悉...
    99+
    2024-04-02
  • Redis在项目中的应用场景有哪些
    了解Redis在项目中的应用场景有哪些?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!Redis是一个开源的底层使用C语言编...
    99+
    2024-04-02
  • Redis的应用场景是什么
    小编给大家分享一下Redis的应用场景是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一丶Redis介绍Redis是一个开源...
    99+
    2024-04-02
  • Redis在PHP中的常见应用场景
    Redis是一种基于内存的键值存储数据库,它具有高性能、高可用性、高可扩展性等优点,被广泛应用于各个领域的数据存储和缓存优化。在PHP应用场景中,Redis也有着广泛的应用,本文主要介绍Redis在PHP中常见的应用场景。缓存优化缓存优化是...
    99+
    2023-05-15
    应用场景 PHP redis
  • Redis的使用场景是什么
    这篇文章主要介绍“Redis的使用场景是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Redis的使用场景是什么”文章能帮助大家解决问题。Redis常用命令总结:包括时间复杂度总结与具体数据类型...
    99+
    2023-06-02
  • Golang Facade模式在中大型项目中的应用场景
    在中大型项目中,Golang Facade模式可以应用于以下场景中:1. 复杂系统的简化接口:中大型项目通常包含多个子系统,每个子系...
    99+
    2023-10-08
    Golang
  • C++ 函数重载在实际项目中的应用场景?
    函数重载允许在 c++++ 中以不同方式定义具有相同名称的函数,处理不同类型的参数或执行不同操作。具体应用场景包括:处理不同数据类型提供不同的功能提高代码可读性 C++ 函数重载在实际...
    99+
    2024-04-26
    c++ 函数重载 代码可读性
  • Redis数据类型及应用场景是什么
    小编给大家分享一下Redis数据类型及应用场景是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. string类型1-1 ...
    99+
    2024-04-02
  • Redis的11种Web应用场景分别是什么
    Redis的11种Web应用场景分别是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一些Redis原语命令比如LPUSH、...
    99+
    2024-04-02
  • 响应函数numy在PHP中的应用场景是什么?
    在PHP中,响应函数numy是一种非常重要的函数,它可以用于各种场景中,包括数学计算、数据分析、图像处理等等。本文将介绍响应函数numy的基本用法和在PHP中的应用场景。 一、什么是响应函数numy? 响应函数numy是一个强大的数学库,它...
    99+
    2023-11-09
    numy 响应 函数
  • Redis的应用场景都是怎样的
    今天就跟大家聊聊有关Redis的应用场景都是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、缓存String类型例如:热点数据缓存(例如报表...
    99+
    2024-04-02
  • Java Load接口在Linux中的应用场景是什么?
    Java Load接口是Java语言中一个重要的接口,其主要作用是在Java程序中加载动态库文件,以实现与本地C/C++代码的交互。在Linux操作系统中,Java Load接口的应用场景非常广泛,本文将着重探讨Java Load接口在L...
    99+
    2023-10-14
    load 接口 linux
  • ASP 关键字在 Django 中的应用场景是什么?
    ASP(Active Server Pages)是一种用于动态网页开发的技术,而Django则是一种基于Python的Web框架。在Django中,ASP关键字可以用于多种应用场景,本文将详细介绍ASP在Django中的应用。 ASP关键字...
    99+
    2023-08-22
    关键字 unix django
  • Redis中有哪些应用场景
    本篇内容介绍了“Redis中有哪些应用场景”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Redis数据类型...
    99+
    2024-04-02
  • Redis在电商系统中的作用及应用场景
    Redis在电商系统中的作用及应用场景,需要具体代码示例随着电商行业的不断发展,大量数据的存储与处理已经成为了电商系统中比较重要的一环。这时候Redis这个高性能缓存数据库就显得尤为重要。在电商系统中,Redis通过其优秀的性能和灵活性,有...
    99+
    2023-11-08
    消息队列 事务处理 数据缓存
  • 二维码在Unix系统中的应用场景是什么?
    二维码是一种二维图像码,是由黑白像素组成的图案,可以用来存储文本、链接、地理位置等信息。它已经被广泛应用于各种场景,例如商业营销、电子支付、物流追踪等。在Unix系统中,二维码也有着广泛的应用场景。 二维码生成器 在Unix系统中,有...
    99+
    2023-08-15
    二维码 unix 索引
  • Redis中HyperLogLog的应用场景有哪些
    基数统计:HyperLogLog可以用于对大数据集中的唯一值进行基数统计,例如统计网站的独立访客数、独立IP数等。 网站UV统计:...
    99+
    2024-05-07
    Redis HyperLogLog
  • 单例模式在PHP项目中的应用场景与扩展思考
    引言单例模式是一种常见的设计模式,它用于限制类的实例化次数,确保在整个应用程序中只有一个实例存在。在PHP项目中,单例模式可以应用于各种场景,如数据库连接、配置文件读取、日志记录等。本文将介绍单例模式在PHP项目中的应用场景,同时探讨如何扩...
    99+
    2023-10-21
    应用场景 单例模式 扩展思考
  • redis的场景应用有哪些
    这篇文章主要介绍“redis的场景应用有哪些”,在日常操作中,相信很多人在redis的场景应用有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”redis的场景应用有哪些”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-04
  • Redis在实时系统中的应用场景有哪些
    缓存:Redis高性能的缓存系统,能够快速地存储和检索数据,提高系统的性能和响应速度。在实时系统中,可以将频繁访问的数据存储在R...
    99+
    2024-05-07
    Redis
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作