前言
redis简单来说 就是一个数据库,不过与传统数据库不同的是 redis 的数据是存在内存中的,所以存写速度非常快,因此 redis 被广泛应用于缓存方向。另外,redis 也经常用来做分布式锁。redis 提供了多种数据类型来支持不同的业务场景。除此之外,redis 支持事务 、持久化、LUA脚本、LRU驱动事件、多种集群方案。所以在面试中我们经常可以看到redis的身影,今天给大家带来一道redis的面试真题以及解析,后面会给大家分享今年来redis常考试的一些真题。
一、秒杀系统架构设计都有哪些关键点?
二、设计秒杀系统时应该注意的5个架构原则
- 架构原则:“4要1不要”
1.1.数据要尽里少
1.2. 请求数要尽里少
1.3.路径要尽里短
1.4.依赖要尽里少
1.5. 不要有单点 - 2不同场景下的不同架构案例
三、如何才能做好动静分离?有哪些方案可选?
- 何为动静数据
- 如何做动静分离的改造
- 动静分离的几种架构方案
方案1:实体机单机部署
方案2:统一Cache 层
方案3:上CDN
四、二八原则:有针对性地处理好系统的“热点数据”
- 为什么要关注热点
- 什么是“热点”
- 发现热点数据
- 处理热点数据
五、流量削峰这事应该怎么做?
- 为什么要削峰
- 排队
- 答题
- 分层过滤
六、影响性能的因素有哪些?又该如何提高系统的性能?
- 影响性能的因素
- 如何发现瓶颈
- 如何优化系统
3.1 减少编码
3.2 减少序列化
3.3. Java 极致优化
3.4.并发读优化
七、秒杀系统“减库存”设计的核心逻辑
- 减库存有哪几种方式
- 减库存可能存在的问题
- 大型秒杀中如何减库存?
- 秒杀减库存的极致优化
八、如何设计兜底方案?
- 高可用建设应该从哪里着手
- 降级
- 限流
- 拒绝服务
完结
Redis基于内存,常用作于缓存的一种技术,并且Redis存储的方式是以key-value的形式。Redis是如今互联网技术架构中,使用最广泛的缓存,在工作中常常会使用到。Redis也是中高级后端工程师技术面试中,面试官最喜欢问的问题之一,因此作为Java开发者,Redis是我们必须要掌握的。
Redis 是 NoSQL 数据库领域的佼佼者,如果你需要了解 Redis 是如何实现高并发、海量数据存储的,那么这份腾讯专家手敲《Redis源码日志笔记》将会是你的最佳选择。
本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录