Java 面试系列 - 分布式缓存

1. 什么是分布式缓存 ?

传统意义上的缓存是保存在应用本身的(JVM),只有应用本身可以对缓存进行读写。在分布式系统中,将缓存抽取出来做成了缓存中间件(数据库),分布式应用都可以对分布式缓存进行读写操作。并且分布式缓存具有高性能和高吞吐量的特性。

2. 为什么使用分布式缓存 ?

分布式缓存主要作用:

  1. 高性能(提高系统性能);
  2. 高并发(提高系统并发);
  3. 减轻关系型数据库压力

2.1 高性能和高并发

随着系统的复杂性和用户量的增加,并发越来越大,我们会发现系统变得越来越慢。因为关系型数据库的 QPS 和 TPS 是有限的,例如 MySQL 数据库,当 QPS 到达 3000 左右的时候(根据实际配置),MySQL 基本上就达到了瓶颈,数据处理就会急剧下降。处理几条查询 SQL 可能会消耗 1 秒左右的时间。

系统性能达到瓶颈后,我们需要性能更高的组件来减轻关系型数据库的压力并提高系统的性能,这个时候分布式缓存就登上了历史的舞台。缓存中的数据以 key-value 的方式存储数据,通过 key 查询 value 耗时大概在 3ms 左右,相比关系型数据 1秒的查询时间,性能提升 300 多倍这就提高了系统的性能。

系统并发达到瓶颈后,我们需要提高并发更高的组件来减轻关系型数据库的压力并提高系统并发性能,这个时候分布式缓存就登上了历史的舞台,例如 Redis QPS 基本稳定在 30000。相比关系型数据有 10 倍左右的提升。

我们可以把关系型数据库的数据查询出来存放到分布式缓存中,以提高系统的性能和并发性。当然分布式缓存还有许多其它用途:缓存、排行榜、计数器、分布式会话、分布式锁、涉及网络(点赞、关注、好友)、最新列表、消息系统、即时通讯 等。

在这里插入图片描述

3. 分布式缓存引入的优缺点

3.1 优点

分布式缓存可以提高系统的性能、提高系统并发、减轻关系型数据库的压力。

3.2 缺点

  1. 提高系统的复杂度
  2. 缓存系统与关系型数据库双写下数据不一致的问题
  3. 缓存雪崩
  4. 缓存击穿
  5. 缓存穿透
  6. 缓存并发竞争
  7. 运维成本增加

4. 参考文献

MySQL 5.7测试结果 (aliyun.com)

云数据库 MySQL 性能白皮书 - 白皮书 - 文档中心 - 腾讯云 (tencent.com)

独享型测试数据_云数据库 RDS_性能白皮书_MySQL_MySQL 5.7测试数据_华为云 (huaweicloud.com)

On Redis, Memcached, Speed, Benchmarks and The Toilet (antirez.com)

测试结果 (aliyun.com)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值