Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >突破Java面试(19) - 分布式缓存的第一个问题

突破Java面试(19) - 分布式缓存的第一个问题

原创
作者头像
JavaEdge
发布于 2019-05-11 11:53:00
发布于 2019-05-11 11:53:00
5380
举报
文章被收录于专栏:JavaEdgeJavaEdge

1 面试题

在项目中缓存是如何使用的?缓存如果使用不当会造成什么后果?

2 考点分析

这个问题,互联网公司必问,要是一个人连缓存都不太清楚,那确实比较尴尬

只要问到缓存,上来第一个问题,肯定能是先问问你项目哪里用了缓存?为啥要用?不用行不行?如果用了以后可能会有什么不良的后果?

这就是看看你对你用缓存这个东西背后,有没有思考,如果你就是傻乎乎的瞎用,没法给面试官一个合理的解答。那我只能说,面试官对你印象肯定不太好,觉得你平时思考太少,就知道干活儿。

3 详解

一个一个来看

3.1 在项目中缓存是如何使用的?

这个,你结合你自己项目的业务来,你如果用了那恭喜你,你如果没用那不好意思,你硬加也得加一个场景吧

3.2 为啥在项目里要用缓存呢?

用缓存,主要是俩用途,高性能和高并发

3.2.1 高性能

  • 缓存是如何实现高性能的
01_缓存是如何实现高性能的.png
01_缓存是如何实现高性能的.png

假设这么个场景,你有个操作,一个请求过来,吭哧吭哧你各种乱七八糟操作mysql,半天查出来一个结果,耗时600ms。但是这个结果可能接下来几个小时都不会变了,或者变了也可以不用立即反馈给用户。那么此时咋办?

缓存啊,折腾600ms查出来的结果,扔缓存里,一个key对应一个value,下次再有人查,别走mysql折腾600ms了。直接从缓存里,通过一个key查出来一个value,2ms搞定。性能提升300倍。

这就是所谓的高性能。

就是把你一些复杂操作耗时查出来的结果,如果确定后面不咋变了,然后但是马上还有很多读请求,那么直接结果放缓存,后面直接读缓存就好了。

3.2.2 高并发

  • 缓存是如何实现高并发的
02_缓存是如何实现高并发的.png
02_缓存是如何实现高并发的.png

mysql这么重的数据库,压根儿设计不是让你玩儿高并发的,虽然也可以玩儿,但是天然支持不好。mysql单机支撑到2000qps也开始容易报警了。

所以要是你有个系统,高峰期一秒钟过来的请求有1万,那一个mysql单机绝对会死掉。你这个时候就只能上缓存,把很多数据放缓存,别放mysql。缓存功能简单,说白了就是key-value式操作,单机支撑的并发量轻松一秒几万十几万,支撑高并发so easy。单机承载并发量是mysql单机的几十倍。

3.3 所以你要结合这俩场景考虑一下,你为啥要用缓存?

一般很多同学项目里没啥高并发场景,那就别折腾了,直接用高性能那个场景吧,就思考有没有可以缓存结果的复杂查询场景,后续可以大幅度提升性能,优化用户体验,有,就说这个理由,没有??那你也得编一个出来吧,不然你不是在搞笑么

3.4 缓存的不良后果

呵呵。。。你要是没考虑过这个问题,那你就尴尬了,面试官会觉得你头脑简单,四肢也不发达。你别光是傻用一个东西,多考虑考虑背后的一些事儿。

常见的缓存问题有以下几点

  • 缓存与数据库双写不一致
  • 缓存雪崩
  • 缓存穿透
  • 缓存并发竞争

这是常见面试题,后面我要讲,大家看到后面自然就知道了,但是人要是问你,你至少自己能说出来,并且给出对应的解决方案

X 交流学习

Java交流群

博客

Github

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
redis的使用技巧(一)
假设这么个场景,你有个操作,一个请求过来,吭哧吭哧你各种乱七八糟操作mysql,半天查出来一个结果,耗时600ms。但是这个结果可能接下来几个小时都不会变了,或者变了也可以不用立即反馈给用户。那么此时咋办?
胡齐
2020/04/08
4080
redis的使用技巧(一)
大厂Java面试题解(19) - 真正搞懂为啥互联网都使用分布式缓存
假设你有个操作,一个请求过来,各种操作MySQL,半天查出来一个结果,耗时600ms。 但这结果可能接下来几个小时都不会再变,或者变了也可以不用立即反馈给用户。那么此时咋办?
JavaEdge
2020/05/27
4580
redis
只要问到缓存,上来第一个问题,肯定能是先问问你项目哪里用了缓存?为啥要用?不用行不行?如果用了以后可能会有什么不良的后果?
大学里的混子
2019/03/16
1.2K0
项目中缓存是如何使用的?为什么要用缓存?
假设这么个场景,你有个操作,一个请求过来,吭哧吭哧你各种乱七八糟操作 mysql,半天查出来一个结果,耗时 600ms。但是这个结果可能接下来几个小时都不会变了,或者变了也可以不用立即反馈给用户。那么此时咋办?
IT技术小咖
2019/11/22
1.5K0
为啥互联网都使用分布式缓存
假设一个请求,各种操作MySQL,半天才查出来一个结果,但这结果可能接下来几个小时都不会再变,或变了也可不用立即返给用户。
JavaEdge
2021/02/22
1980
突破Java面试(45)-高并发系统的架构设计
所以如果你确实有真才实学,在互联网公司里干过高并发系统,那你确实拿offer基本如探囊取物,没啥问题。
JavaEdge
2019/07/12
1.1K0
突破Java面试(45)-高并发系统的架构设计
面试官:你对Redis缓存了解吗?面对这11道面试题你是否有很多问号?
只要问到缓存,上来第一个问题,肯定是先问问你项目哪里用了缓存?为啥要用?不用行不行?如果用了以后可能会有什么不良的后果?
程序员追风
2020/05/06
1.3K0
Redis常见面试题
假设这么个场景,你有个操作,一个请求过来,吭哧吭哧你各种乱七八糟操作 mysql,半天查出来一个结果,耗时 600ms。但是这个结果可能接下来几个小时都不会变了,或者变了也可以不用立即反馈给用户。那么此时咋办?
鱼找水需要时间
2023/03/31
2750
大厂Java面试题解(45)-来设计个高并发系统?
技术强的人,在互联网公司肯定负责过高并发模块,那夺取offer太简单了。可惜大部分初级工程师甚至高并发代码都没想过怎么写! 不是说只要用个redis缓存,用个mq异步削峰就搞定了!真实的要复杂很多倍。
JavaEdge
2021/02/22
7100
大厂Java面试题解(45)-来设计个高并发系统?
Redis常见面试题
假设这么个场景,你有个操作,一个请求过来,吭哧吭哧你各种乱七八糟操作 mysql,半天查出来一个结果,耗时 600ms。但是这个结果可能接下来几个小时都不会变了,或者变了也可以不用立即反馈给用户。那么此时咋办?
鱼找水需要时间
2023/12/24
2650
如何设计一个高并发的高可用系统?
如何设计一个支持高并发的高可用服务?在前期设计时应该从哪些方面入手?明确的一点:没有哪一个系统是从一开始设计时就是高可用的,支持高并发的。都是在产品的发展壮大中,随着业务量的增加,逐渐对系统架构进行一步步升级。
小东啊
2019/11/14
2.3K0
这5个常问的Redis面试题你答得出来吗?(详细剖析)
在前几年,redis 如果要搞几个节点,每个节点存储一部分的数据,得借助一些中间件来实现,比如说有codis,或者 twemproxy,都有。有一些 redis 中间件,你读写 redis 中间件,redis 中间件负责将你的数据分布式存储在多台机器上的 redis 实例中。
用户2781897
2020/10/10
5980
这5个常问的Redis面试题你答得出来吗?(详细剖析)
《吊打面试官》系列-Redis终章_凛冬将至 FPX_新王登基
Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。作为一个在互联网公司面一次拿一次offer的面霸(请允许我使用一下夸张的修辞手法),打败了无数竞争对手,每次都只能看到无数落寞的身影失望的离开,略感愧疚,在一个寂寞难耐的夜晚,我痛定思痛,决定开始写《吊打面试官》系列,希望能帮助各位读者以后面试势如破竹,对面试官进行360°的反击,吊打问你的面试官,让一同面试的同僚瞠目结舌,疯狂收割大厂offer!
敖丙
2019/12/19
4990
《吊打面试官》系列-Redis终章_凛冬将至  FPX_新王登基
中华石杉Java面试突击第一季笔记三(分布式缓存)
整合了商品名称、价格、图片、简介的商品详情页就是典型的场景,可以把通过复杂操作耗时查询出来的结果,确定短时间内不会频繁更新变化,但是对这个数据会有大量读请求,这个时候就可以直接把结果存放在缓存中,后面的请求就直接读取缓存即可。
chenchenchen
2022/03/09
5950
中华石杉Java面试突击第一季笔记三(分布式缓存)
这个场景题很常见,一定要会!
鱼皮最新原创项目教程,欢迎学习 大家好,我是鱼皮。 今天给大家分享一道场景设计题目:如何设计一个高并发系统。并给大家整理了高并发系统设计的 15 个锦囊,相信大家看完会有帮助的。 如何理解高并发系统 所谓设计高并发系统,就是设计一个系统,保证它整体可用的同时,能够处理很高的并发用户请求,能够承受很大的流量冲击。 我们要设计高并发的系统,那就需要处理好一些常见的系统瓶颈问题,如内存不足、磁盘空间不足,连接数不够,网络宽带不够等等,以应对突发的流量洪峰。 1. 分而治之,横向扩展 如果你只部署一个应用,只
程序员鱼皮
2023/03/29
6110
这个场景题很常见,一定要会!
《吊打面试官》系列-Redis双写一致性、并发竞争、线程模型
Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。作为一个在互联网公司面一次拿一次offer的面霸(请允许我使用一下夸张的修辞手法),打败了无数竞争对手,每次都只能看到无数落寞的身影失望的离开,略感愧疚,在一个寂寞难耐的夜晚,我痛定思痛,决定开始写《吊打面试官》系列,希望能帮助各位读者以后面试势如破竹,对面试官进行360°的反击,吊打问你的面试官,让一同面试的同僚铩羽而归,疯狂收割大厂offer!
Remember_Ray
2020/08/05
1.1K0
除了背八股文,Java面试更该这样准备
我可以这样说,哪怕你背了再多java八股文的答案,过面试也能靠运气,因为很多java面试的答案只限于技术理论说辞。但用我本文给出的方法去准备面试,能在不提升技术的前提下,大大提升你java面试的通过率。
用户1153489
2021/12/28
7740
缓存与数据库双写,不一致问题及解决方案
你只要用缓存,就可能会涉及到缓存与数据库双存储双写,你只要是双写,就一定会有数据一致性的问题,那么你如何解决一致性问题?
李红
2019/05/29
1.6K0
高并发系统设计的15个锦囊
记得很久之前,去面试过字节跳动。被三面的面试官问了一道场景设计题目:如何设计一个高并发系统。当时我回答得比较粗糙,最近回想起来,所以整理了设计高并发系统的15个锦囊,相信大家看完会有帮助的。
捡田螺的小男孩
2023/02/24
8790
高并发系统设计的15个锦囊
想进阿里、京东、美团面试的Java程序员看过来第一个问题:阿里面试问些什么
第一个问题:阿里面试问些什么 参加阿里的社招面试,而社招不同于校招,问题的范围其实是很随机的。因为能参加一些比较知名的互联网公司社招的人,70%以上都会有个3-5年的经验。这倒不是说一两年经验的同学没有机会进这些公司,而是因为这种公司,大部分情况下只招一些比较资深的开发和应届生,而不招那些处于中间阶段的人。而1-2年经验的同学,往往就刚好处于这个尴尬的阶段。 对于能有3-5年经验的这部分人中,每个人的经历又都不同,所擅长的点也不一样,因此这就会导致每个人的问题和范围都不太一样。 很少说有哪个知名的互联网公司
美的让人心动
2018/06/14
8020
推荐阅读
相关推荐
redis的使用技巧(一)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档