一、缓存分类

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. dva.js 用法详解:列表展示

    本教程案例github:https://github.com/axel10/dva_demo-Counter-and-list/tree/master 这次主要通过在线获取用户数据并且渲染成列表这个案 ...

  2. jqgrid 单元格引入时间datepicker控件

    简述原理:引入jquery-ui插件,设置好表格所需的字段变量以及字段属性1.设置colName与colModel colNames: ['过期时间''] colModel:[{       name ...

  3. Qt下载地址

    上Qt官网http://www.qt.io/download/想下载Qt,速度很慢,在这里记录下在Qt官网看到的镜像下载地址: 1. 所有Qt版本下载地址: http://download.qt.io ...

  4. Kon-boot v2.5介绍与使用方法总结(支持win10)

    Kon-boot这个工具相信大家都不陌生,这是一款专门针对Windows.Linux.MAC登陆密码破解工具,他能绕过系统所设有的登陆密码,让你的登陆畅通无阻.KON-Boot的原理是在于处理BIOS ...

  5. 如何提高windows的性能

    默认windows启用了很多的效果,我们可能平时没有注意到,比如什么淡入淡出效果之类的,其实在我看来,这些效果不仅难看,而且影响了windows的性能,下面我就来说说怎么通过关闭这些效果来提高wind ...

  6. 对thinkphp的命名空间的理解

    tp的命名空间其实就是虚拟目录,目的是为了自动加载类(不是管理文件) tp命名空间包含两部分: (1)初始命名空间:Library (2)根命名空间: a)Library文件下的所有文件夹,只含一级文 ...

  7. Java 小记 — Spring Boot 注解

    前言 本篇随笔将对 Spring Boot 中的常用注解做一个简单的整理归档,写作顺序将从启动类开始并逐步向内外扩展,目的即为了分享也为了方便自己日后的回顾与查阅. 1. Application 启动 ...

  8. ERROR : PHP中错误基础

    1.错误 在进行PHP代码编辑的时候,容易碰到error错误提示,PHP中错误有两种:语法错误.逻辑错误. 2.错误报告类型 Notice : 通知 比如直接使用未定义的变量,这种错误不影响PHP脚本 ...

  9. ASP.NET MVC编程——验证、授权与安全

    1 验证  一般采用表单验证完成登陆验证,建议结合SSL使用.为限制控制器只能执行HTTPS,使用RequireHttpsAttribute 2 授权 对账户的权限的控制可以通过在控制器或控制器操作上 ...

  10. 常用到的html页面布局和组件: 自己用

    1. 用div当作圆 <div style="border: 1px solid blue;height: 100px; width: 100px; border-radius: 20 ...