分布式 之 缓存
随着流量不断增大,数据库的压力也越来越大。需要缓存技术来缓解其压力。
缓存相关问题及解决:
缓存击穿:某一个热点数据缓存失效(过期),造成大量用户直奔DB的现象。
解决方案:
- 开一个监控线程进行时间更新(不推荐)
- 提前设置好时间,保证热点数据在高峰期不过期
缓存雪崩:大量缓存全部失效(大量缓存设置了相同过期时间;缓存所在服务器出现故障)
解决方案:
- 合理分配缓存的过期时间
- 搭建缓存集群
缓存穿透:防止恶意攻击。不缓存无意义的数据,而用户故意访问,发送无意义数据请求
解决:
将无意义数据也缓存,并设置较短的过期时间。
通过上述可知:这些问题都是因缓存失效造成的,我们可以通过分布式缓存/二级缓存来解决。
S:计算各服务器IP的Hash值并取模运算(服务器个数)
B:计算请求资源的Hash值,同上取余进行匹配访问服务器
问题:当服务器个数改变时,缓存会失效。
解决:使用一致性Hash,2的32次方------Hash环
计算各服务器IP的Hash值并取模运算(2的32次方),仍然会出现缓存失效,但概率很小。
新问题:Hash倾斜
解决:生成虚拟节点,再找真实节点
需要注意的是:缓存一致性问题,即缓存与数据库同步
-
不推荐:当DB更新后,立刻更新缓存。先删除缓存,再更新DB。
-
推荐:当DB更新后,立刻删除缓存