Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >0x01缓存基本概念一览

0x01缓存基本概念一览

作者头像
上善若水.夏
发布于 2018-09-28 03:34:39
发布于 2018-09-28 03:34:39
6000
举报
文章被收录于专栏:上善若水上善若水

tags: redis,ehcahe,jcache,memcache

缓存机制的引入可以提高系统的访问效率。

它的主要实现思想是:在程序和数据源之间引入一个中间层即Cache,访问cache的时间成本肯定远低于数据源。

按照Cache所在可以简单分为进程外缓存和本地缓存。

对于单机推荐使用 ehcahe

对于分布式 推荐使用 redis 和   MemCached;

  1. SpringBoot支持很多种缓存方式:redis、guava、ehcahe、jcache等等。
  2. Redis && memcache 缓存中间件:属于独立的运行程序 可以单机部署,也可以分布式部署;
  3. ehcache: 是程序的一个功能模块。 缓存的访问速度快,但不太适合分布式部署。
  4. 读写速度,不考虑并发问题,本地缓存是最快的
缓存预热

在缓存初始化时,缓存中是没有任何缓存数据的,需先将数据缓存后,缓存服务才算完全启动。预热方式:

  • miss后,实时查询,然后更新缓存数据;
    1. 缺点1:多个tomcat实例同时查询数据并跟新缓存,在一段时间内缓存近似于失效;
    2. 缺点2:在高并发场景下,无法限制对数据库访问速度;
  • 通过task或接口预先加载服务,然后开启缓存服务;
    1. 优势1:在初始化服务时,限制加载数据的速度;
    2. 优势2:批量查询数据库,减少与数据库之间的网络交互;
缓存穿透的问题

问题:

  • 缓存穿透是指查询一个根本不存在的数据,缓存层和存储层都不会命中,
  • 缓存穿透将导致不存在的数据每次请求都要到存储层去查询,失去了缓存保护后端存储的意义。

原因:代码问题, 爬虫,攻击,大量空命中

场景:查询某个文章,给了一个错误的文章id。一直查询不到。

方法:

缓存空对象

  • 空值做缓存,即缓存层中存了更多的键,这就需要更多的内存空间 ,可以对其设置一个较短的过期时间,让其自动清除。
  • 优点是实时性高,代码维护简单。

可以缓存到本地内存中,空对想用一个静态变量。这样不会造成 造成占用内存。

参考链接
  1. ehcache、memcache、redis三大缓存比较
  2. MemCached vs Redis 对象缓存的比较
  3. 总结:如何使用redis缓存加索引处理数据库百万级并发
  4. 学习笔记:cache 和spring cache 技术---本地缓存-分布式缓存,缓存穿透,雪崩,和热点key的问题
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.09.18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Java面试考点5之缓存
缓存是高并发场景下提高热点数据访问性能的一个有效手段,在开发项目时会经常使用到。缓存的类型分为:本地缓存、分布式缓存和多级缓存。
马拉松程序员
2022/04/26
4580
Java面试考点5之缓存
缓存小结(二)
可以通过部署多个节点,同时设计一些方案让这些节点互为备份。这样,当某个节点故障时,它的备份节点可以顶替它继续提供服务。这些方案就是分布式缓存的高可用方案。主要有客户端方案、中间代理层方案和服务端方案三大类。
WindCoder
2020/01/21
6040
微服务缓存,你真的用对了么?
导读:如今,缓存系统的应用非常广泛,能够用来提高并发数、数据吞吐量,提高快速响应能力。那么当数据量达到一定程序,单机环境可能就显得有些力不从心了,就需要一个分布式缓存系统。
码农架构
2021/09/18
1.1K0
微服务缓存,你真的用对了么?
后台开发必备:每个程序员都应掌握的缓存技术
缓存(Cache)是一种存储技术,可以存储数据,以便快速获取数据。缓存最重要的是两个特性:存储、快速获取。缓存的本质:「用空间换时间」,用快速存储的介质保存数据,以提升数据访问的速度。
腾讯云开发者
2024/07/02
1K0
后台开发必备:每个程序员都应掌握的缓存技术
Java缓存深入理解
对于缓存大家都不会陌生,但如何正确和合理的使用缓存还是需要一定的思考,本文将基于Java技术栈对缓存做一个相对详细的介绍,内容分为基本概念、本地缓存、远程缓存和分布式缓存集群几个部分,重点在于理解缓存
用户1216676
2018/01/24
10.6K1
大型高并发与高可用的三层缓存架构总结
对于高并发架构,毫无疑问缓存是最重要的一环,对于大量的高并发,可以采用三层缓存架构来实现,nginx+redis+ehcache nginx 对于中间件nginx常用来做流量的分发,同时nginx本身
Java高级架构
2018/04/19
1.6K0
大型高并发与高可用的三层缓存架构总结
大型高并发与高可用的三层缓存架构总结
作者:高级架构师 文章来自:https://my.oschina.net/u/3772106/blog/1616343 nginx 对于中间件nginx常用来做流量的分发,同时nginx本身也有自己的
java思维导图
2018/03/15
1.1K0
大型高并发与高可用的三层缓存架构总结
分布式缓存的选择
如今,缓存系统的应用非常广泛,能够用来提高并发数、数据吞吐量,提高快速响应能力。那么当数据量达到一定程序,单机环境可能就显得有些力不从心了,就需要一个分布式缓存系统。
肉眼品世界
2020/12/17
5920
理解分布式系统中的缓存架构(上)
CDN(Content Delivery Network 内容分发网络)的基本原理是广泛采用各种缓存服务器,将这些缓存服务器分布到用户访问相对集中的地区或网络中,在用户访问网站时,利用全局负载技术将用户的访问指向距离最近的工作正常的缓存服务器上,由缓存服务器直接响应用户请求
lyb-geek
2018/08/16
1.3K0
理解分布式系统中的缓存架构(上)
缓存那些事
前言 一般而言,现在互联网应用(网站或App)的整体流程,可以概括如图1所示,用户请求从界面(浏览器或App界面)到网络转发、应用服务再到存储(数据库或文件系统),然后返回到界面呈现内容。 随着互联网的普及,内容信息越来越复杂,用户数和访问量越来越大,我们的应用需要支撑更多的并发量,同时我们的应用服务器和数据库服务器所做的计算也越来越多。但是往往我们的应用服务器资源是有限的,且技术变革是缓慢的,数据库每秒能接受的请求次数也是有限的(或者文件的读写也是有限的),如何能够有效利用有限的资源来提供尽可能大的吞吐量
美团技术团队
2018/03/12
2.8K0
缓存那些事
必知必会:关于缓存的一些重要概念
很多朋友,只知道缓存可以提高系统性能以及减少请求相应时间,但是,不太清楚缓存的本质思想是什么。
架构之家
2022/07/12
4450
必知必会:关于缓存的一些重要概念
相关推荐
Java面试考点5之缓存
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档