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

Redis模块二:缓存分类 + Redis模块三:常见缓存(应用)

缓存大致可以分为两大类:
1)本地缓存
2)分布式缓存

目录

本地缓存

分布式缓存

常见缓存的使用 

本地缓存:Spring Cache  

分布式缓存:Redis  


本地缓存

本地缓存也叫单机缓存,也就是说可以应⽤在单机环境下的缓存。所谓的单机环境是指,将服务部署到⼀台服务器上,如下图所示: 

举个例子:
本地缓存相当于每家企业的公司规定⼀样,不同的公司规定也是不同的,比如上班时间,不同的公司上班时间规定也是不同的,对于企事业单位来说⼀般要求 9:00-17:00 上班,而对于酒吧来说,这个时间就完全不适合了。  
所以,本地缓存的特征是只适⽤于当前系统。  

分布式缓存

分布式缓存是指可以应⽤在分布式系统中的缓存。所谓的分布式系统是指将⼀台服务器部署到多台服务器,并且通过负载分发将⽤户的请求按照⼀定的规则分发到不同服务器,如下图所示:  

举个例子:
分布式缓存相当于适⽤于所有公司的规定,⽐如无论是任何公司都不能偷税漏税,不能做违反法律的事情,这种情况就和分布式缓存很像,适⽤于所有的系统。⽐如我们在分布式系统中的服务器 A 中存储了⼀个缓存 key=themyth,那么在服务器 B 中也可以读取到 key=themyth 的数据,这样情况就是分布式缓存的作⽤。  

常见缓存的使用 

本地缓存的常见使⽤:Spring Cache、MyBatis 的缓存等。
分布式缓存的常见使⽤:Redis 和 Memcached。  

本地缓存:Spring Cache  

在 Spring Boot 项⽬,可以直接使⽤ Spring 的内置 Cache(本地缓存),只需要完成以下三个步骤就可以正常使⽤了:
1. 开启缓存
2. 操作缓存
3. 调⽤缓存 

在 Spring Boot 的启动类上添加如下代码,开启缓存:

① 开启缓存  

② 编写缓存操作代码

 在 Service 层增加三个缓存操作的方法:添加缓存、修改缓存、删除缓存,示例代码如下:

③ 编写触发(调⽤)代码  

以上步骤执行完之后,可以使用 Postman 模拟调⽤来查看缓存。   

分布式缓存:Redis  

在 Spring 框架中我们也可以直接操作 Redis 缓存,它的操作流程如下图所示:   

Redis 和 Memcached 的区别

1.存储方式不同:memcache 把数据全部存在内存之中,断电后会挂掉,数据不能超过内存⼤⼩;Redis 有部份存在硬盘上,这样能保证数据的持久性
2.数据⽀持类型:memcache 对数据类型⽀持相对简单;
Redis 有复杂的数据类型
3.存储值⼤⼩不同
Redis 最⼤可以达到 512mb,memcache 只有 1mb。

总结:通常情况下,如果是单机 Spring 项⽬,会直接使⽤ Spring Cache 作为本地缓存,如果是分布式环境⼀般会使⽤ Redis。  

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

相关文章:

  • Revit SDK 内容摘要: 8.0 -8.1
  • 列表和字典练习
  • iwebsec靶场 文件包含漏洞通关笔记2-文件包含绕过(截断法)
  • 【基于Cocos Creator实现的赛车游戏】9.实现汽车节点的控制逻辑
  • 蓝蓝设计为教育行业提供软件UI交互设计服务
  • Java从入门到精通-类和对象(二)
  • Python解析MDX词典数据并保存到Excel
  • 线性代数的本质(四)
  • FreeMarker详细介绍
  • 房地产小程序 | 小程序赋能,房地产业务数字化升级
  • Databend 开源周报第 110 期
  • 开源大模型ChatGLM2-6B 1. 租一台GPU服务器测试下
  • SQL10 用where过滤空值练习
  • JVM--Hotspot Architecture 详解
  • ThreadLocal功能实现
  • Linux编辑器-vim使用
  • 自助式数据分析平台:JVS智能BI功能介绍(二)数据集管理
  • 《5G技术引领教育信息化新革命》
  • cmake学习过程记录
  • Vue3、Vite使用 html2canvas 把Html生成canvas转成图片并保存,以及填坑记录
  • centos yum源配置(CentOS7 原生 yum 源修改为阿里 yum 源)
  • linux————ansible
  • 初识Java 8-1 接口和抽象类
  • 微信小程序音频后台播放功能
  • NotePad——xml格式化插件xml tools在线安装+离线安装
  • 图书管理系统 数据结构先导课暨C语言大作业复习 | JorbanS
  • python 爬虫的开发环境配置
  • 技术架构图是什么?和业务架构图的区别是什么?
  • 数据增强
  • 【Unity】2D 对话模块的实现