当前位置: 首页 > news >正文

Redis进阶--缓存

目录

一、引言

二、介绍

1.为什么Mysql的速度慢呢?

2.缓存更新策略

1.定期生成

2.实时生成

3.redis的内存淘汰机制

4.注意事项

1.缓存预热

2.缓存穿透

3.缓存击穿

4.缓存雪崩

三、总结


一、引言

  本篇文章将介绍Redis其中一个重要的作用,作为缓存。

二、介绍

Redis中的数据主要是存储在内存中,读取速度比硬盘快得多。

Redis一般是作为Mysql的缓存

1.为什么Mysql的速度慢呢?

1.数据存储在硬盘上,磁盘的IO速度并不快,尤其是随机访问

2.查询有时候没有走索引,直接全表扫描了,速度下降

3.如果是复杂的查询,比如联合查询,需要进行笛卡尔积的操作,速度会更慢

2.缓存更新策略

1.定期生成

会把访问的数据以日志的形式记录下来

统计这一段时间这些数据使用的频率,然后将这些数据设置为热点数据,放入Redis中

之后规定一定的时间自己去生成这些热点数据

缺点:不能及时的更新,如果某个不是热点数据的数据忽然变成了热点数据,不能及时更新到redis中

2.实时生成

先去redis中查,查到了就返回。如果没有查到就去mysql中查到,然后写入到redis中

但是这样redis会越写越多,怎么解决呢?

3.redis的内存淘汰机制

1.写满了之后就不允许写入了(不适合于实时更新)

2.没有过期时间:淘汰使用频率最低的,随机淘汰

3.有过期时间:淘汰使用频率最低的,随机淘汰,淘汰时间即将过期的

淘汰存在最久的(FIFO),淘汰使用频率最低的(LFU),淘汰最近一次使用时间最久的(LRU),随机淘汰(RANDOM)

4.注意事项

1.缓存预热

项目刚启动的时候,先将部分没有访问的数据放入到redis中

2.缓存穿透

查询的某个key,在redis中不存在,在mysql中也没有,大量的请求都到达mysql了,会使得mysql宕机。

解决方式:1.进行参数检查  2.当一个key查找数据库中不存在时,把一个空对象或者默认值保存在缓存中,之后再访问这个数据,从缓存中获取(存在的问题:缓存中有更多的key了,占用空间,数据不一致问题)。3.布隆过滤器:会保存数据是否存在,如果判断数据不在,就不会访问存储层。

3.缓存击穿

某个时期一个热点key突然过期了,导致大量请求打到mysql上,导致mysql挂掉

解决方式:1.对热点key永不过期

2.服务降级:关闭一些不是特别重要的功能

4.缓存雪崩

由于短时间内,大规模的key失效了,缓存命中率大幅下降,mysql的压力迅速上升,甚至于宕机

解决方式:1.加强监控报警,加强redis集群可用性的保证

2.设置过期时间的时候添加一个随机的因子/不设置过期时间

三、总结

  本篇文章简单介绍了Redis作为缓存的作用以及常见出现故障的情况,感谢观看!

http://www.lryc.cn/news/594913.html

相关文章:

  • 如何使用python网络爬虫批量获取公共资源数据
  • 微软CEO Satya Nadella提出AI重构法则:从范式跃迁到社会盈余
  • 本地生活服务 app 同城信息发布系统搭建
  • delphi disqlite3 操作sqlite
  • C# 计算梯形面积和周长的程序(Program to calculate area and perimeter of Trapezium)
  • 在Windows Server 2012 R2中安装与配置IIS服务并部署mssql靶机教程
  • 【世纪龙科技】新能源汽车概论-汽车教学数字课程资源
  • 如何编写假设和约束---SRS软件需求规格指南系列
  • 概率论与数理统计(八)
  • 【跨国数仓迁移最佳实践2】MaxCompute SQL执行引擎对复杂类型处理全面重构,保障客户从BigQuery平滑迁移
  • java和ptyhon对比
  • C# Lambdab表达式 Var 类
  • PyQt5—QInputDialog 学习笔记
  • Iridium Certus 9704 卫星物联网开发套件
  • uniapp app pdf.js报错:Uncaught SyntaxError:Unexpected token ‘{‘
  • UART串口
  • 学习日志7.21
  • QT6 源,七章对话框与多窗体(6) 颜色对话框 QColorDialog :本类的属性,信号函数,静态成员函数,以及源代码
  • 使用AI把普通的条形柱状图,丰富成“好看高大上”的条形柱状图
  • Three.js实现银河流光粒子星空特效原理与实践
  • 基于ECharts的电商销售可视化系统(数据预测、WebsSocket实时聊天、ECharts图形化分析、缓存)
  • 【LINUX操作系统】搭建web网络服务器
  • Softhub软件下载站实战开发(二十):Docker部署全攻略
  • Golang在Web开发中的应用
  • 网络协议(四)网络层 路由协议
  • uni-app 开发小程序项目中实现前端图片压缩,实现方式
  • uniapp使用uni-ui怎么修改默认的css样式比如多选框及样式覆盖小程序/安卓/ios兼容问题
  • 云原生周刊:K8s 中的后量子密码学
  • 【iOS】锁[特殊字符]
  • 类似腾讯会议的私有化音视频会议软件,BeeWorks Meet