一、服务网关简介

1、外观模式

客户端与各个业务子系统的通信必须通过一个统一的外观对象进行,外观模式提供一个高层次的接口,使得子系统更易于使用:

简单说一下外观模式,网关和这个模式很像,但是比外观模式复杂,模式,结构,原则这些都是通用的,在各种架构或组件中使用。

2、网关简介

微服务网关从感觉上,很像是:拦截器+路由+过滤器,拦截请求,系列基础处理,路由转发到指定服务。

服务网关在整个架构体系上也是一个服务器,作为请求的唯一入口,与外观模式十分类似,在网关层处理所有的非业务功能,为客户端提供定制的API,在网关层通常会执行如下操作:如权限校验、监控、负载均衡、缓存、日志、限流、等等。

二、网关模式

1、模式对比

这里对比常用的请求服务管理模式,和网关模式,如图:

常规模式

在没有网关的情况下,微服务架构会在业务层服务上提供一个API服务,用来接收参数,例如Client-API,通常会根据系统模块划分多个API,例如,运营系统,用户系统等。

  • 请求统一进入Client-API服务 ;
  • Client-API经过鉴权,限流,路由等操作;
  • 如果请求通过,会转发到相应业务服务上;
  • 如果请求被拦截,会直接返回给客户端;
  • Client-API集成所有业务服务的开放接口;

该模式下的缺点非常明显,每个Client-API都需要实现一套非业务服务,代码冗余,当系统膨胀之后,维护成本极高,适用于轻量级系统架构。

网关模式

在业务服务层上,添加一层网关控制,在服务网关中可以完成一系列的横切非业务功能:

  • 客户端请求在网关层做统一拦截;
  • 网关上执行:路由/鉴权/限流/降级等操作;
  • 网关判断是转发请求还是直接响应客户端;

网关服务层要执行很多非业务流程,作为系统的服务端唯一入口,承受所有服务的路由转发,安全,限流,缓存,日志,监控,熔断降级等功能,网关服务不仅要做到高可用,还要避免出现性能瓶颈。

2、多重网关

在大型复杂的系统中,通常会对网关做分层管理,把一类业务规划到一个网关下,避免网关过于臃肿,方便维护和管理:

总网关:通用常用来做路由转发功能;

模块网关:分类的业务服务聚合网关,对这类服务的做非业务性操作,最后请求转发到具体服务上,在数据类平台上,通常对数据通道(流入流出)做一层独立的服务网关;对数据分析类服务做一层独立网关;基本是根据服务的使用情况来划分,这样避免单层服务网关过于复杂的情况。

三、核心功能

1、配置层面

服务发现

网关应该有服务发现功能,通过统一注册中心,获取服务列表,这样才能执行统一代理服务和路由转发功能。

路由请求

植入网关层服务之后,客户端不知道自己请求的是哪个具体的服务,只需要把请求转发给网关,网关放行之后会把请求路由到指定业务服务上。

负载均衡

网关连接的服务实例可能是集群模式存在,所以网关还可以对各个服务实例上执行负载均衡策略,常见的策略就是服务轮询或者按权重路由。

2、定制开发

定制开发例如:权限校验,日志集成,接口限流,等相关功能,需要和数据库交互,可以做成独立服务,在服务中实现具体的处理逻辑,网关层直接调用即可。

四、网关组件

1、Netflix-Zuul

Zuul网关主要提供动态路由,监控,弹性,安全管控等功能。在分布式的微服务系统中,系统被拆为了多个微服务模块,通过zuul网关对用户的请求进行路由,转发到具体的后微服务模块中,Netflix开源的一个基于JVM路由和服务端的负载均衡器。

2、Tyk组件

Tyk是一个开源的、轻量级的、快速可伸缩的API网关,支持配额和速度限制,支持认证和数据分析,支持多用户多组织。基于go语言编写,在Java架构系统中使用很少。

3、Kong组件

Kong是一款基于Nginx+Lua编写的高可用,可扩展的开源网关项目,由Mashape公司开放。核心是实现数据库抽象,路由和插件管理,插件可以存在于单独的代码库中,并且可以在几行代码中注入到请求生命周期的任何位置。提供易于使用的RESTfulAPI来操作和配置API管理,并且可以水平扩展多个Kong服务器,通过前置的负载均衡配置把请求均匀地分发到各个Server,来应对高并发的网络请求。


C++轻量级微服务_微服务技术栈:API网关中心,落地实现方案相关推荐

  1. qiankun 微前端_微前端方案 qiankun(实践及总结)

    ❝ 作者:沉末_ 链接:https://juejin.im/post/5ed73b73e51d4578724e3fa4 ❞ 什么是微前端? 我们先来看两个实际的场景: 1. 复用别的的项目页面 通常, ...

  2. 微服务的简介和技术栈

    一.简介 这些年软件的设计规模越来越庞大,业务需求也越来越复杂,针对系统的性能.高吞吐率.高稳定性.高扩展等特性提出了更高的要求.可以说业务需求是软件架构能力的第一推动力,由于这些因素导致了软件架构思 ...

  3. 什么是微服务_微服务系列笔记:什么是微服务?

    作者 | 莫无崖 导语 微服务(Microservice Architecture)是近几年流行的一种架构思想,它的概念没有很明确的指出.ThoughtWorks 公司的首席科学家 Martin Fo ...

  4. eureka跨服务_微服务(microservices) 资料总结

    微服务是商业应用程序开发中最热门的新事物.微服务这个词取代了敏捷.DevOps和RESTful,成为了所有简历和大会演讲中都必须提及的新热门词. 微服务这一概念出现于2012年,因敏捷开发方法创始人之 ...

  5. ajax请求是宏任务还是微任务_微服务-如何解决链路追踪问题

    一.链路追踪 微服务架构是将单个应用程序被划分成各种小而连接的服务,每一个服务完成一个单一的业务功能,相互之间保持独立和解耦,每个服务都可以独立演进.相对于传统的单体服务,微服务具有隔离性.技术异构性 ...

  6. 庐山真面目之一 微服务的简介和技术栈

    一.简介          这些年软件的设计规模越来越庞大,业务需求也越来越复杂,针对系统的性能.高吞吐率.高稳定性.高扩展等特性提出了更高的要求.可以说业务需求是软件架构能力的第一推动力,由于这些因 ...

  7. 异步服务_微服务全链路异步化实践

    1. 背景 随着公司业务的发展,核心服务流量越来越大,使用到的资源也越来越多.在微服务架构体系中,大部分的业务是基于Java 语言实现的,受限于Java 的线程实现,一个Java 线程映射到一个ker ...

  8. 微服务技术栈:API网关中心,落地实现方案

    本文源码:GitHub·点这里 || GitEE·点这里 一.服务网关简介 1.外观模式 客户端与各个业务子系统的通信必须通过一个统一的外观对象进行,外观模式提供一个高层次的接口,使得子系统更易于使用 ...

  9. 异构服务器 微服务_微服务架构是什么?

    如果你懂或者不理解,希望你看到这篇文章之后就能搞懂. 以下: 正文 看到最近"微服务架构"这个概念这么火,作为一个积极上进的程序猿,成小胖忍不住想要学习学习.而架构师老王(不是隔壁 ...

最新文章

  1. URI、URL以及URN的区别
  2. Nature今年首次撤稿给了微软:研究团队成员自曝删改不利数据,量子计算重大进展是假的...
  3. 通过StringBuilder的reverse()实现倒序
  4. spring mvc工作原理及组件说明
  5. matlab产生mif 文件,生成.mif文件的matlab程序
  6. 解读 | 滴滴主题研究计划:机器学习专题+
  7. HTML5崛起之时,Java桌面时代就已经终结了
  8. codeforces B. Pasha and String(贪心)
  9. 调用模块里的action_初级测试人员进阶必备Python编码模块,看过的都说好
  10. 为什么要对1000000007取模
  11. android 扫描SDCard.
  12. 【转载】数据仓库的基本架构
  13. CodeForces - 808B Average Sleep Time
  14. H3C Comware的作用
  15. mysql 每日备份脚本分享
  16. Spring懒加载机制原理和配置讲解
  17. [cocos2dx开发技巧4]工具CocosBuilder的使用--复杂动画
  18. e470换高分屏_DIY之Thinkpad E470升级记
  19. GIT用SSH链接的相关文档的整理与补充
  20. Android P版本应用兼容性适配技术指导

热门文章

  1. Redis之GeoHash
  2. Java B2B2C多用户电子商务平台SpringCloud/Boot
  3. .NET MVC Scripts.Render 上下文不存在问题解决方法
  4. android 上线流程
  5. Perl 6 语言的糟粕
  6. wikioi 1163 訪问艺术馆 树形dp
  7. Single Page Applications in ASP.NET MVC 4
  8. 桌面虚拟化之用户评估指南 (翻译)
  9. WPF ListBox(ListView) 自定义 Button 项,获取 ListBox(ListView)的SelectedValue
  10. hadoop java访问_Hadoop(五)搭建Hadoop客户端与Java访问HDFS集群