首页 > 数据库 >Redis使用场景

Redis使用场景

时间:2023-11-08 18:02:58浏览次数:37  
标签:队列 场景 网站 Redis 排行榜 缓存 使用 数据


核心知识点:

1.Redis可以做什么:缓存、排行榜、消息队列、计数器和社交网络。

2.Redis不适合做什么:不适合大数据规模的存储和冷数据的存储。

 

一、Redis可以做什么

1.缓存

缓存机制几乎在所有的大型网站都有使用,合理地使用缓存不仅可以加快数据的访问速度,而且能够有效地降低后端数据源地压力。

Redis提供了键值过期时间设置,并且也提供了灵活控制最大内存和内存溢出后地淘汰策略。

可以这么说,一个合理地缓存设计能够为一个网站的稳定保驾护航。

 

2.排行榜系统

排行榜系统几乎存在于所有的网站,例如按照热度排名的排行榜,按照发布时间的排行榜,按照各种复杂维度计算出的排行榜,

Redis提供了列表和有序集合数据结构,合理地使用这些数据结构可以很方便地构建各种排行榜系统。

 

3.计数器使用

计数器在网站中地作用至关重要,例如视频网站有播放数、电商网站有浏览数,为了保证数据地实时性,

每次播放和浏览都要做加1的操作,如果并发量很大对于传统关系性数据的性能是一种挑战。

Redis天然支持计数功能而且计数的性能也非常好,可以说是计数系统的重要选择。

 

4.社交网络

赞/踩、粉丝、共同好友/喜好、推送、下拉刷新等是社交网站的必备功能,由于社交网站访问量通常比较大,

而且传统的关系型数据不太适合保存这种类型的数据,Redis提供的数据结构可以相对比较容易地实现这些功能。

 

5.消息队列系统

消息队列系统可以说是一个大型网站的必备基础组件,因为其具有业务解耦、非实时业务削峰等特性。

Redis提供了发布订阅功能和阻塞队列的功能,虽然和专业的消息队列比还不够强大,但是对于一般的消息队列功能基本可以满足。

 

 

二、Redis不可以做什么

实际上和任何一门技术一样,每个技术都有自己的应用场景和边界,也就是说Redis并不是万金油,

有很多适合它解决的问题,但是也有很多不适合它解决的问题。

我们可以站在数据规模和数据冷热的角度来进行分析。

 

站在数据规模的角度看,数据可分为大规模数据和小规模数据,我们知道Redis的数据是存放在内存中的,

虽然现在内存已经足够便宜,但是如果数据量非常大,例如每天有几亿的用户行为数据,

使用Redis来存储的话,基本上是无底洞,经济成本相当的高。

 

站在数据冷热的角度看,数据分为热数据和冷数据,热数据通常是指需要频繁操作的数据,反之为冷数据,

例如对于视频网站来说,视频基本信息基本上在各个业务线都是经常要操作的数据,

而用户的观看记录不一定是经常需要访问的数据,这里暂时不讨论两者数据规模的差异,

单纯站在数据冷热的角度上看,视频信息属于热数据,用户观看记录属于冷数据。

如果将这些数据放在Redis中,基本上是对内存的一种浪费,但是对于一些热数据可以放在Redis中加速读写,也可以减轻后端存储的负载,可以说是事半功倍。



标签:队列,场景,网站,Redis,排行榜,缓存,使用,数据
From: https://blog.51cto.com/u_809530/8257182

相关文章

  • pyqt5-designer简单使用和代码简单说明
    学习pyqt,实际上主要是逐个学习ui组件。 1、designer的简单使用(1)创建窗口主要是QWidget类窗口和QMainWindow窗口的使用。后者支持窗口菜单栏的实现。(2)拖动(3)布局和预览(4)查看组件属性(5)对象名称和类的 2、简单的代码说明(1)窗口中的所有ui组件,是作为窗口对象的......
  • Redis配置文件详解
    Redis的配置文件redis.conf过滤掉空行和注释行,总共有49个可控项。1daemonizeno默认情况下,redis不是后台运行,如果需要后台运行,把该项的值改为yes。2pidfile当Redis在后台运行的时候,Redis默认会把pid文件放在/var/run/redis.pid,你可以配置到其他地址。当运行多个redis服务时,需......
  • Redis shell
                                                                        Redisshell命令参数功能redis-cli-r将一个命令执行多次-i每隔几秒执行一次-x和|一起接收前面地输出,并执行命令-c -a --scan/--patt......
  • Redis切片集群
    切片集群多个Redis实例组成一个集群,然后按照一定的规则,把收到的数据划分成多份,每一份用一个实例来保存。RedisCluster定义Redis官方提供的实现切片集群的方案,采用了16384个哈希槽用于处理数据和实例的映射关系。首先根据key计算哈希槽hash_slot=CRC16(key)%16384,其次......
  • linux udev 的使用
    1、如何在文件系统中选择  Systemconfiguration ---> /devmanagement(Dynamicusingdevtmpfs+eudev) ---> Targetpackages --->Hardwarehandling --->  -*-eudevenablerulesgenerator......
  • 在bat中使用forfiles遍历文件,示例:删除N天之前文件
    Windows定时删除N天之前文件(最新推荐)复制一下内容,粘贴至delete.bat文件中。脚本说明:“D:\test”为文件删除路径。-7为7天之前forfiles/p"D:\test"/s/m*.*/d-7/c"cmd/cdel@path":pause在任务管计划中创建执行脚本的计划,定时执行就好了,这里就不演示了,可以查看......
  • 使用HBase命令错误问题--ERROR: KeeperErrorCode = ConnectionLoss for /hbase/master
    问题描述按照以往的顺序和环境打开hbase的shell界面,出现了这样的问题:问题解决是的!还没解决~~......
  • 使用pillow对图像进行旋转和添加高斯白噪声
    高斯白噪声defadd_gaussian_noise(image,mean=0,std=25):"""给图像添加高斯噪声。:paramimage:输入图像:parammean:噪声均值:paramstd:噪声标准差:return:添加噪声后的图像"""image=np.array(image)h,w,c=im......
  • PHP使用php_stl计算STL模型体积和表面积
    使用composer安装chubv/php-stl包<?phprequire_once'vendor/autoload.php';usePHPSTL\Handler\VolumeHandler;usePHPSTL\Handler\SurfaceHandler;usePHPSTL\Reader\STLReader;$reader=newSTLReader();$reader=$reader->forFile('./......
  • 重庆上百位老师和学生,正在使用这个国产操作系统
    你是否还记得,当年进学校机房前穿鞋套的经验?那时的电脑稀有昂贵,普通家庭需要几个月的工资才能买上一台,于是信息课上短暂的45分钟,成为了每个孩子走进数字世界的钥匙。随着技术的发展,电脑已经成为日常生活中不可或缺的一部分,也推动着教育领域的数字化转型,使其更好地适应社会的需要。......