你好,我是小牛。
最近,面试了几家大厂,基本都会问到中间件相关技能,问的比较多的就是消息中间件mq和redis缓存数据库。
关于大厂为什么喜欢问这些,原因也比较简单。因为实际工作中确实经常用到这些中间件,我们不会针对这些中间件专门去做测试,但是会基于一些业务场景去测试,如果不懂的话,测试起来肯定就一脸懵逼了。
限于篇幅,今天我们就先来聊聊中间件redis缓存数据库,主要讲关于工作中的一些使用,为什么使用redis,以及面试会经常问哪些问题。首先来说下redis是什么?它是一种非关系性数据库,是介于接口服务端和数据库的中间层。
比如一个查询接口,第一次查询从数据库查数据,查完之后我们把数据存入redis缓存中,第二次查就可以直接从缓存中读取数据,这就是它的用法。那么一般我们把什么数据存入redis缓存中呢?主要是一些复杂操作,耗费时间长的,比如数据库查询要600ms,但是redis只需要20ms。
而且,在接下来的几个小时内,这个数据都不会变化,我们就可以存入缓存数据库,为什么对时间有要求呢?因为缓存中的数据一般都是有过期时间的,这个开发写代码可以设置。
再来说下我们为什么使用redis,它的优势是什么?主要有以下几个原因:
读取速度快。因为缓存是写入内存中的,普通数据库数据是写在磁盘中的,基于内存的相比于磁盘速度是快很多的,但是也缺点,比如断电之后,内存中的数据会消失,磁盘则不会。
高并发,减轻数据库压力。一旦涉及大数据量需求,比如一些商品抢购等,或者主页瞬间访问量大的时候,磁盘读写上千上万次,有性能弊端。容易造成数据库瘫痪,服务器宕机。数据库顶不住,需要缓存分担一部分压力。
然后再来说一下redis的数据类型是什么?这个面试被问到的非常频繁。主要有五种,字符串,哈希,列表,集合,有序集合。上面说的都是一些比较基础的面试题,一般公司问上面那些就差不多了。但是如果更进一步的话,面试官就会问讲一下redis的雪崩,缓存穿透,缓存击穿机制是什么?
相关文章
- 07-25阿里P7亲自讲解!阿里技术官整合的四大主流中间件笔记
- 07-25设计消息中间件时我关心什么?(解密电商数据一致性与完整性实现,含PPT)(转发)
- 07-25我的架构梦:(八十八)消息中间件之Kafka如何保证幂等性
- 07-25我的架构梦:(九十八)消息中间件之RocketMQ的高可用机制——消息发送高可用
- 07-25SAP CRM中间件Request download的警告信息:Form of address 0001 not designated for organization
- 07-25全网写得最好的分库分表之 Sharding-JDBC 中间件介绍
- 07-25消息中间件ActiveMQ的简单使用-Spring整合开发(2)
- 07-25Django学习-18-中间件
- 07-25Django框架之中间件MiddleWare
- 07-25Redux中间件