(三)总结(缓存/ETag请求头)


文章目录

  • 项目地址
  • 一、缓存
    • [1.1 Cache-Control Header(不常用)](#1.1 Cache-Control Header(不常用))
    • [1.2 ETag请求头(不常用)](#1.2 ETag请求头(不常用))
  • 二、乐观锁
  • [三、HTTP Resilience/Polly/Rate limit](#三、HTTP Resilience/Polly/Rate limit)
    • [3.1 HTTP Resilience](#3.1 HTTP Resilience)
    • [3.2 Polly](#3.2 Polly)
    • [3.3 Rate limit](#3.3 Rate limit)
  • [四、Idempotent Request Header](#四、Idempotent Request Header)

项目地址

  • 教程作者:
  • 教程地址:
复制代码
  • 代码仓库地址:
复制代码
  • 所用到的框架和插件:

    dbt
    airflow

一、缓存

1.1 Cache-Control Header(不常用)

  • 直接在Controller的顶部写上缓存的事件
    1. 在依赖注入里添加缓存服务
    2. 注册缓存中间件在program里
    3. 在Controller的头部添加缓存

1.2 ETag请求头(不常用)

  1. 创建InMemoryETagStore类,用来设置,获取和更新内存中的ETag
  2. 实现ETagMiddleware类,用于对内存中的ETag进行判断
  3. 注册InMemoryETagStore服务和ETagMiddleware

二、乐观锁

  1. 添加使用乐观锁的请求类型 put和patch
  2. 在上面Etag的基础上,添加ifMatch请求头
  3. 判断当前内存中的Etag和请求头中的ifMatch是否相等
  4. 如果不相同,就说明有并发数据不一致问题
  5. 在会出现并发问题的controller的方法里注入InMemoryETagStore服务
  6. 在数据存储后,设置新的Etag值

三、HTTP Resilience/Polly/Rate limit

3.1 HTTP Resilience

  • 解决请求外部api时候,遇到的错误,并且自动恢复
    1. 直接在Refit服务配置后面,实现重试,熔断等策略

3.2 Polly

  • 失败重试3次,如果还失败,就停留30s后在请求

3.3 Rate limit

  • 给登用户使用token bucket策略
  • 给匿名用户使用Fixed Window策略

四、Idempotent Request Header

相关推荐
一眼万年042 小时前
Kafka APIs 深度解析:请求处理架构与核心流程
微服务·kafka
一眼万年042 小时前
NGINX 高并发 HTTP 处理深度解析
nginx·微服务
bing_1583 小时前
在微服务架构中,怎么搭建Maven私服
微服务·架构·maven
蓝色天空的银码星13 小时前
SpringCloud微服务架构下的日志可观测解决方案(EFK搭建)
spring cloud·微服务·架构
春生野草19 小时前
MyBatis中关于缓存的理解
java·缓存·mybatis
掘金-我是哪吒1 天前
分布式微服务系统架构第147集:JavaPlus技术文档平台日更
分布式·微服务·云原生·架构·系统架构
Gazer_S1 天前
【Web 应用缓存与部署优化指南】
前端·缓存
异常君1 天前
Dubbo 与 Spring Cloud Gateway 技术对比:微服务架构中的协同实践
spring cloud·微服务·dubbo
小鸡脚来咯1 天前
redis穿透、击穿、雪崩
数据库·redis·缓存