前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >看完这篇,中间件面试大厂稳了!

看完这篇,中间件面试大厂稳了!

作者头像
测试小牛
发布2022-04-25 20:25:23
3110
发布2022-04-25 20:25:23
举报
文章被收录于专栏:测试小牛进阶测试小牛进阶

你好,我是小牛。

最近,面试了几家大厂,基本都会问到中间件相关技能,问的比较多的就是消息中间件mq和redis缓存数据库。

关于大厂为什么喜欢问这些,原因也比较简单。因为实际工作中确实经常用到这些中间件,我们不会针对这些中间件专门去做测试,但是会基于一些业务场景去测试,如果不懂的话,测试起来肯定就一脸懵逼了。

限于篇幅,今天我们就先来聊聊中间件redis缓存数据库,主要讲关于工作中的一些使用,为什么使用redis,以及面试会经常问哪些问题。

首先来说下redis是什么?它是一种非关系性数据库,是介于接口服务端和数据库的中间层。

比如一个查询接口,第一次查询从数据库查数据,查完之后我们把数据存入redis缓存中,第二次查就可以直接从缓存中读取数据,这就是它的用法。

那么一般我们把什么数据存入redis缓存中呢?主要是一些复杂操作,耗费时间长的,比如数据库查询要600ms,但是redis只需要20ms。

而且,在接下来的几个小时内,这个数据都不会变化,我们就可以存入缓存数据库,为什么对时间有要求呢?因为缓存中的数据一般都是有过期时间的,这个开发写代码可以设置。

再来说下我们为什么使用redis,它的优势是什么?主要有以下几个原因:

  1. 读取速度快。因为缓存是写入内存中的,普通数据库数据是写在磁盘中的,基于内存的相比于磁盘速度是快很多的,但是也缺点,比如断电之后,内存中的数据会消失,磁盘则不会。
  2. 高并发,减轻数据库压力。一旦涉及大数据量需求,比如一些商品抢购等,或者主页瞬间访问量大的时候,磁盘读写上千上万次,有性能弊端。容易造成数据库瘫痪,服务器宕机。数据库顶不住,需要缓存分担一部分压力。

然后再来说一下redis的数据类型是什么?这个面试被问到的非常频繁。主要有五种,字符串,哈希,列表,集合,有序集合。

上面说的都是一些比较基础的面试题,一般公司问上面那些就差不多了。但是如果更进一步的话,面试官就会问讲一下redis的雪崩,缓存穿透,缓存击穿机制是什么?

1.雪崩机制

假设数据库访问量是每秒5千请求,redis数据库可以抗住每秒4千请求。但是redis数据库因为意外宕机,那么这五千个请求就会全部打到数据库上。

这个时候数据库就挂掉了,这个时候如果没有特别的方案来处理这个故障,DBA直接重启数据库,那么马上又会被新的流量打死,这个就是redis雪崩机制。

2.缓存穿透

假设一个系统每秒5千请求,但是有4千是黑客恶意攻击发起的,缓存中差不到,数据库中也查不到。

比如说,数据库id都是从1开始的,但是黑客发过来的请求id都是负数,所以缓存中查不到,就会直接打到数据库,数据库就会挂掉,这种就是缓存穿透。

3.缓存击穿

这个就是说某个缓存数据库的key值,访问非常频繁,一直处于高并发访问,但是因为一些原因这个key失效,那么数据流量就把缓存击穿,瞬间打到数据库上,就像在屏风上凿开一个洞。

以上,就是关于缓存数据库的一些技能点,都是面试过程中经常会遇到的,掌握这些,面试基本就没什么问题了,大家也可以网上看一些博客,继续深入研究一下。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-08-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 测试小牛进阶 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档