【退役之重学Java】关于缓存

一、为什么要用缓存

缓存嘛,对比计算机组成原理中的"高速缓存控制器",就可以知道,缓存的存在是为了获取高性能,特别是在高并发场景下获取高性能。

二、缓存是如何获取高性能的

  1. SQL的执行是非常消耗性能的
  2. 有一些SQL经常是一样的,返回一样的结果
  3. 那么重复地去数据库中执行这些SQL,就显得不必要
  4. 这时,可以设置缓存,将此类相同的SQL,以及其查询结果存放在缓存中
  5. 那么理论上,只要数据库中的数据没有改变,就可以直接从缓存中获取数据,而不用去数据库执行SQL
  6. 所以,就减轻了数据库的负担,增加了系统的性能,减少了用户等待时间,提高了用户使用体验感
  7. 如果数据库的数据发生变化,在修改数据库中的数据同时,把缓存中的数据也做相应修改(当然,根据不用的业务场景和需求,可以采用不同的修改策略)

三、缓存是如何实现高并发的

  • 缓存用的是内存,内存的读写速度很快,所以能极大的提高性能
  • 采用并发控制访问、缓存分片、缓存集群、缓存策略优化、缓存预热、缓存监控和调优等设计和方法,以实现对高并发的支持

四、缓存可能存在的问题

  1. 缓存与数据库双写不一致
  2. 缓存雪崩
  3. 缓存穿透
  4. 缓存并发竞争
相关推荐
papership3 分钟前
【入门级-C++程序设计:11、指针与引用-引 用】
c语言·开发语言·c++·青少年编程
岁忧6 分钟前
(LeetCode 每日一题) 1780. 判断一个数字是否可以表示成三的幂的和 (数学、三进制数)
java·c++·算法·leetcode·职场和发展·go
一颗星的征途1 小时前
java循环分页查询数据,任何把查询到的数据,分批处理,多线程提交到数据库清洗数据
java·数据库·mysql·spring cloud
常乐か1 小时前
VS2022+QT5.15.2+OCCT7.9.1的开发环境搭建流程
开发语言·qt·opencascade
浩少7021 小时前
LeetCode-16day:栈
java·数据结构·算法
布朗克1682 小时前
Java中Record的应用
java·record类型
Evand J2 小时前
【MATLAB例程】滑动窗口均值滤波、中值滤波、最小值/最大值滤波对比。附代码下载链接
开发语言·matlab·均值算法
IT毕设实战小研2 小时前
基于SpringBoot的救援物资管理系统 受灾应急物资管理系统 物资管理小程序
java·开发语言·vue.js·spring boot·小程序·毕业设计·课程设计
yzx9910132 小时前
PHP 开发全解析:从基础到实战的进阶之路
开发语言·php