一、缓存分类

1、服务注册信息

1.1、GroupCode_VersionCode】对应【Version定义】的缓存

           

          缓存类型:hash

          缓存key:API:GrpVer:groupCode_VersionCode

          缓存val: version定义

          使用方式:String versionId = jedis.hget(RedisCachePrefix.getApiGrpVerKey(groupCode, versionCode), "id");

          更新场景:version上线, version下线修改后重新上线,version下线(王静)

          引擎缓存:无缓存,无监听

1.2、API 定义:API:ApiDef_

        缓存名称:

        缓存类型:

        缓存格式:api定义列表

        初始时机:version上线

        更新时机:version下线才能更新

        销毁时机:version下线

        引擎缓存:有,订阅 [apigateway.apis:online,offline] 事件

1.3、后端签名密钥:API:BckKey_

        缓存名称:

        缓存类型:

        缓存格式:SvcClientKey,"SvcClientSecret:SvcClientId:OwnerId:OwnerName" >

        初始时机:后端签名密钥创建

        更新时机:后端签名密钥重置

        销毁时机:无

        引擎缓存:无

2、服务使用信息

2.1、前端签名密钥:API:FrtKey_

        缓存名称:

        缓存类型:

        缓存格式:DevClientKey_VersionId,"DevClientSecret:InstId:DevClientId:OwnerId:OwnerName" >  ,绑定、解绑刷新

        初始时机:前端签名密钥绑定

        更新时机:前端签名密钥重置

        销毁时机:服务使用实例回收,回收时删除服务使用实例,(周鲁,遍历解除绑定,干掉绑定缓存)

        引擎缓存:无

2.2、服务使用策略:API:InstPol_

        缓存名称:

        缓存类型:

        缓存格式:<InstId_ApiId_Policy, Map<策略Key,策略Val> > 

        

       初始时机:服务使用申请审核、服务使用升级申请审核时,缓存服务使用策略

        更新时机:升级申请审批的时候,更新服务使用实例,同步刷新缓存数据

        销毁时机:服务使用实例回收

        引擎缓存:无

3、网关运行期缓存(引擎自维护)

3.1、请求随机数(nonce):API:ChkNon_

        缓存名称:

        缓存类型: 

        缓存格式:<api_nonceid, "" > 

        初始时机:该请求第一次访问

        更新时机:无

        销毁时机:目前每分钟自动销毁,有效期可配置(启庆)

        引擎缓存:无

3.2、API访问频次:API:ChkFrq_

        初始时机:该API第一次访问

        更新时机:该API每次访问

        销毁时机:无

        引擎缓存:无

3.3、配额检查:API:ChkQut_

        初始时机:该API第一次访问

        更新时机:该API每次访问

        销毁时机:无

        引擎缓存:无

二、缓存刷新

1、版本管理

1.1、版本上线

配置中心:缓存 version定义、api定义

网关引擎:订阅更新 本地的version定义和api定义缓存(骞骞验证一下)

1.2、版本下线

配置中心:干掉version定义、api定义缓存

网关引擎:订阅更新,干掉本地的version定义和api定义缓存(骞骞验证一下)

2、后端密钥管理

2.1、后端密钥创建

配置中心:缓存后端密钥

网关引擎:无缓存,不需要动作

2.2、后端密钥绑定

配置中心: version需要先下线再上线,所以绑定关系会随版本重新上线刷新

网关引擎:无缓存,不需要动作

2.3、后端密钥解绑

配置中心:version需要先下线再上线,所以绑定关系会随版本重新上线销毁

网关引擎:无缓存,不需要动作

3、审批申请

3.1、审批使用申请

配置中心:产生服务使用实例,刷新策略缓存

网关引擎:无缓存,不需要动作

3.2、审批使用升级申请

配置中心:更新服务使用实例,刷新策略缓存

网关引擎:无缓存,不需要动作

3.3、回收服务使用实例

配置中心:去掉前端密钥缓存、服务使用实例缓存(包括svcUserId)

网关引擎:无缓存

4、前端密钥管理

4.1、前端密钥创建

配置中心:无缓存动作

网关引擎:无缓存

4.2、前端密钥绑定

配置中心:增加前端密钥缓存

网关引擎:无缓存

4.3、前端密钥解绑

配置中心:去掉前端密钥缓存

网关引擎:无缓存

5、一键刷新

配置中心:一键刷新,刷新所有的缓存,发布【apigateway.refreshAll】事件

网关引擎:刷新网关本地缓存

api-gateway实践(05)新网关工作 - 缓存定义的更多相关文章

  1. .net core 微服务之Api网关(Api Gateway)

    原文:.net core 微服务之Api网关(Api Gateway) 微服务网关目录 1. 微服务引子 2.使用Nginx作为api网关 3.自创api网关(重复轮子) 3.1.构建初始化 3.2. ...

  2. 分享一个国内首个企业级开源的GO语言网关--GoKu API Gateway

    一. 简介 GoKu API Gateway,中文名:悟空API网关,是国内首个开源go语言API网关,帮助企业进行API服务治理与API性能安全维护,为企业数字化赋能. GoKu API Gatew ...

  3. 微服务实战(二):使用API Gateway

    微服务实战(一):微服务架构的优势与不足 微服务实战(二):使用API Gateway 微服务实战(三):深入微服务架构的进程间通信 微服务实战(四):服务发现的可行方案以及实践案例 微服务实践(五) ...

  4. [转载] 构建微服务:使用API Gateway

    原文: http://mp.weixin.qq.com/s?__biz=MzA5OTAyNzQ2OA==&mid=206889381&idx=1&sn=478ccb35294c ...

  5. 微服务实战-使用API Gateway

    当你决定将应用作为一组微服务时,需要决定应用客户端如何与微服务交互.在单体式程序中,通常只有一组冗余的或者负载均衡的服务提供点.在微服务架构中,每一个微服务暴露一组细粒度的服务提供点.在本篇文章中,我 ...

  6. 使用API Gateway

    http://dockone.io/article/482 [编者的话]本系列的第一篇介绍了微服务架构模式.它讨论了采用微服务的优点和缺点,除了一些复杂的微服务,这种模式还是复杂应用的理想选择. Do ...

  7. 微服务实战(二):使用API Gateway - DockOne.io

    原文:微服务实战(二):使用API Gateway - DockOne.io [编者的话]本系列的第一篇介绍了微服务架构模式.它讨论了采用微服务的优点和缺点,除了一些复杂的微服务,这种模式还是复杂应用 ...

  8. 谈谈微服务中的 API 网关(API Gateway)

    前言 又是很久没写博客了,最近一段时间换了新工作,比较忙,所以没有抽出来太多的时间写给关注我的粉丝写一些干货了,就有人问我怎么最近没有更新博客了,在这里给大家抱歉. 那么,在本篇文章中,我们就一起来探 ...

  9. 微服务中的 API 网关(API Gateway)

    API 网关(API Gateway)提供高性能.高可用的 API 托管服务,帮助用户对外开放其部署在 ECS.容器服务等云产品上的应用,提供完整的 API 发布.管理.维护生命周期管理.用户只需进行 ...

随机推荐

  1. P2P技术简介

    P2P技术简介 NAT( Network Address Translation)穿越(俗称打洞)技术 前言: p2p已经存在于我们生活的方方面面:我们通过下载在工具(比如迅雷,bitorent,各种 ...

  2. Android开发——签名包的生成

    前言: 最近想要在酷安网上传apk,注册开发者的时候需要申请验证,验证需要两个apk,一个是自己的apk(需要签名),另外一个则是下载酷安的模板生成的一个签名包(使用的签名要与之前的签名自己的apk一 ...

  3. APNS IOS 消息推送沙盒模式和发布模式

    在做.NET向IOS设备的App进行消息推送时候,采用的是PushSharp开源类库进行消息的推送,而在开发过程中,采用的是测试版本的app,使用的是测试的p12证书采用的是ApnsConfigura ...

  4. 2018-3 WebStorm最新版本破解方法

    今天重新打开WebStorm发现之前输入的License Server没法用了,不能通过WebStorm的检测,搜索良久,终于找到了最新版本WebStorm的破解方法. 在激活页面选择License ...

  5. 常见排序算法及Java实现

    先上个总图↓: ①.直接插入排序 插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法.它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并 ...

  6. C#枚举数值与名称的转换实例分享

    首先建立一个枚举: 复制代码代码如下: /// <summary>    /// 颜色    /// </summary>    public enum ColorType   ...

  7. python基础整理----基本概念和知识

    整理一下python的基本概念和知识, 主要用python3为语法标准. python介绍 一种面向对象的解释性计算机设计语言,具有丰富和强大的库. python定位:"优雅".& ...

  8. 9.FileWriter 和 BufferWriter

    FileWriter 和 BufferWriter的使用场景 http://www.cnblogs.com/xjyh/p/4529809.html

  9. 关于html文档的规范

    1. <!DOCTYPE html> 告诉浏览器该文档使用哪种html或xhtml的规范 2. 元数据中的X-UA-Compatible <meta http-equiv=" ...

  10. 一篇关于Maven项目的jar包Shell启动脚本

    使用Maven作为项目jar包依赖的管理,常常会遇到命令行启动,笔者也是哥菜鸟,在做微服务,以及服务器端开发的过程中,常常会遇到项目的启动需要使用main方法,笔者潜心的研究了很多博客,发现大多写的都 ...