前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >面试必问:缓存预热、降级?

面试必问:缓存预热、降级?

作者头像
八点半的Bruce、D
发布2022-12-05 10:01:59
4690
发布2022-12-05 10:01:59
举报
文章被收录于专栏:八点半技术站八点半技术站

作者:Bruce.D

github:https://github.com/doukoi-BDB

今日主题:

1、redis 的缓存预热?缓存降级?

2、GitHub 仓库更新 weChat - openApi 管理,详情公告

3、GitHub 仓库更新 weChat - 微信支付 管理,详情公告

01

缓存预热、缓存降级

1、缓存预热是指系统上线后,提前将相关的缓存数据加载到缓存系统。避免在用户请求的时候,先查询数据库,然后再将数据缓存的问题,用户直接查询事先被预热的缓存数据。

如果不进行预热,那么Redis初始状态数据为空,系统上线初期,对于高并发的流量,都会访问到数据库中, 对数据库造成流量的压力。

缓存预热解决方案:

  • 数据量不大的时候,工程启动的时候进行加载缓存动作;
  • 数据量大的时候,设置一个定时任务脚本,进行缓存的刷新;
  • 数据量太大的时候,优先保证热点数据进行提前加载到缓存。

2、缓存降级是指缓存失效或缓存服务器挂掉的情况下,不去访问数据库,直接返回默认数据或访问服务的内存数据。降级一般是有损的操作,所以尽量减少降级对于业务的影响程度。

在进行降级之前要对系统进行梳理,看看系统是不是可以丢卒保帅;从而梳理出哪些必须誓死保护,哪些可降级;比如可以参考日志级别设置预案:

一般:比如有些服务偶尔因为网络抖动或者服务正在上线而超时,可以自动降级;

警告:有些服务在一段时间内成功率有波动(如在95~100%之间),可以自动降级或人工降级,并发送告警;

错误:比如可用率低于90%,或者数据库连接池被打爆了,或者访问量突然猛增到系统能承受的最大阀值,此时可以根据情况自动降级或者人工降级;

严重错误:比如因为特殊原因数据错误了,此时需要紧急人工降级。

02

weChat - openApi

仓库地址:https://github.com/doukoi-BDB/Frame-SDK (走过路过来个 stars )

1、文件地址:/Lib/weChatService/

2、详细说明:

03

weChat - 微信支付

仓库地址:https://github.com/doukoi-BDB/Frame-SDK (走过路过来个 stars )

1、文件地址:Frame-SDK/Demo/weChat_pay_H5

2、详细说明:

特殊说明:

1、仓库还有其他demo、类库、函数,均免费使用

2、想要了解的其他功能点,留言&社群告知我即可

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-10-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 八点半技术站 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档