分布式之缓存

分布式 之 缓存

随着流量不断增大,数据库的压力也越来越大。需要缓存技术来缓解其压力。

缓存相关问题及解决:
缓存击穿:某一个热点数据缓存失效(过期),造成大量用户直奔DB的现象。

解决方案:

  1. 开一个监控线程进行时间更新(不推荐)
  2. 提前设置好时间,保证热点数据在高峰期不过期

缓存雪崩:大量缓存全部失效(大量缓存设置了相同过期时间;缓存所在服务器出现故障)

解决方案:

  1. 合理分配缓存的过期时间
  2. 搭建缓存集群

缓存穿透:防止恶意攻击。不缓存无意义的数据,而用户故意访问,发送无意义数据请求

解决:
将无意义数据也缓存,并设置较短的过期时间。

通过上述可知:这些问题都是因缓存失效造成的,我们可以通过分布式缓存/二级缓存来解决。

S:计算各服务器IP的Hash值并取模运算(服务器个数)
B:计算请求资源的Hash值,同上取余进行匹配访问服务器

问题:当服务器个数改变时,缓存会失效。
解决:使用一致性Hash,2的32次方------Hash环

计算各服务器IP的Hash值并取模运算(2的32次方),仍然会出现缓存失效,但概率很小。

新问题:Hash倾斜
解决:生成虚拟节点,再找真实节点

需要注意的是:缓存一致性问题,即缓存与数据库同步
  1. 不推荐:当DB更新后,立刻更新缓存。先删除缓存,再更新DB。

  2. 推荐:当DB更新后,立刻删除缓存

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值