缓存,原来我们一直都用错了!

开发 开发工具
有架构师说“缓存是万金油,哪里有问题,加个缓存,就能优化”,缓存的滥用,可能会导致一些错误用法。

缓存,是互联网分层架构中,非常重要的一个部分,通常用它来降低数据库压力,提升系统整体性能,缩短访问时间。

有架构师说“缓存是万金油,哪里有问题,加个缓存,就能优化”,缓存的滥用,可能会导致一些错误用法。

四类缓存常见误用,你中招了吗?

[[440543]]

误用一:把缓存作为服务与服务之间传递数据的媒介。

如上图:

(1)服务1和服务2约定好key和value,通过缓存传递数据;

(2)服务1将数据写入缓存,服务2从缓存读取数据,达到两个服务通信的目的。 

该方案存在的问题是:

(1)数据管道,数据通知场景,MQ更加适合;

(2)多个服务关联同一个缓存实例,会导致服务耦合。

误用二:使用缓存未考虑雪崩。

常规的缓存玩法,如上图:

(1)服务先读缓存,缓存命中则返回;

(2)缓存不命中,再读数据库。 

什么时候会产生雪崩?

如果缓存挂掉,所有的请求会压到数据库,如果未提前做容量预估,可能会把数据库压垮(在缓存恢复之前,数据库可能一直都起不来),导致系统整体不可服务。

如何应对潜在的雪崩?

提前做容量预估,如果缓存挂掉,数据库仍能扛住,才能执行上述方案。

否则,就要进一步设计,更具体的,有两类常见方案。

方案一:高可用缓存

如上图:使用高可用缓存集群,一个缓存实例挂掉后,能够自动做故障转移。

方案二:缓存水平切分

如上图:使用缓存水平切分,一个缓存实例挂掉后,不至于所有的流量都压到数据库上。

误用三:调用方缓存数据。

如上图:

(1)服务提供方缓存,向调用方屏蔽数据获取的复杂性(这个没问题);

(2)服务调用方,也缓存一份数据,先读自己的缓存,再决定是否调用服务(这个有问题)。

该方案存在的问题是:

(1)调用方需要关注数据获取的复杂性;

(2)更严重的,服务修改db里的数据,淘汰了服务cache之后,难以通知调用方淘汰其cache里的数据,从而导致数据不一致;

(3)有人说,服务可以通过MQ通知调用方淘汰数据,额,难道下游的服务要依赖上游的调用方,分层架构设计不是这么玩的。

误用四:多服务共用缓存实例。

如上图:

(1)服务A和服务B共用一个缓存实例(不是通过这个缓存实例交互数据)。

该方案存在的问题是:

(1)可能导致key冲突,彼此冲掉对方的数据;

画外音:可能需要服务A和服务B提前约定好了key,以确保不冲突,常见的约定方式是使用namespace:key的方式来做key。

(2)不同服务对应的数据量,吞吐量不一样,共用一个实例容易导致一个服务把另一个服务的热数据挤出去;

(3)共用一个实例,会导致服务之间的耦合,与微服务架构的“数据库,缓存私有”的设计原则是相悖的;

建议的玩法是:

如上图:各个服务私有化自己的数据存储,对上游屏蔽底层的复杂性。 

总结

缓存使用小技巧:

(1)服务与服务之间不要通过缓存传递数据;

(2)如果缓存挂掉,可能导致雪崩,此时要做高可用缓存,或者水平切分;

(3)调用方不宜再单独使用缓存存储服务底层的数据,容易出现数据不一致,以及反向依赖;

(4)不同服务,缓存实例要做垂直拆分。

这些坑,你踩过吗?

【本文为51CTO专栏作者“58沈剑”原创稿件,转载请联系原作者】

戳这里,看该作者更多好文 

 

 

责任编辑:赵宁宁 来源: 51CTO专栏
相关推荐

2017-07-18 15:41:56

互动百科

2014-06-25 09:31:53

Android谷歌

2024-09-09 11:11:45

2020-11-05 10:54:29

网络安全安博通

2024-10-14 13:20:00

2021-11-29 18:34:14

内存异步死循环

2023-09-13 17:08:31

2023-09-13 11:19:49

2017-03-03 09:55:25

2020-06-22 13:48:08

SQL查询SELECT

2018-07-03 13:47:45

Facebook数据泄露网络安全

2018-03-21 18:00:15

NestJS

2022-04-26 09:53:30

WiFi网络

2021-06-04 15:50:49

AI 数据人工智能

2015-09-15 17:01:59

2020-05-24 17:15:25

数据泄露网络攻击信息安全

2012-05-18 00:01:07

JVMJavaJVM平台

2010-10-20 11:06:27

公司

2022-01-26 11:14:32

Vim编辑器Linux

2014-04-30 12:18:07

软件设计
点赞
收藏

51CTO技术栈公众号