Spring Cloud Gateway 服务网关快速实现解析
spring cloud gateway 服务网关
api 主流网关有nginx、zuul、spring cloud gateway、linkerd等;spring cloud gateway构建于 spring 5+,基于 spring boot 2.x 响应式的、非阻塞式的 api。同时,它支持 websockets,和 spring 框架紧密集成,用来代替服务网关zuul,开发体验相对来说十分不错。
spring cloud gateway 是 spring cloud 微服务平台的一个子项目,属于 spring 开源社区,依赖名叫:spring-cloud-starter-gateway。
zuul 是 netflix 公司的开源项目,spring cloud 在 netflix 项目中也已经集成了 zuul,依赖名叫:spring-cloud-starter-netflix-zuul。
api 网关
api 网关出现的原因是微服务架构的出现,不同的微服务一般会有不同的网络地址,而外部客户端可能需要调用多个服务的接口才能完成一个业务需求,如果让客户端直接与各个微服务通信,会有以下的问题:
- 客户端会多次请求不同的微服务,增加了客户端的复杂性。
- 存在跨域请求,在一定场景下处理相对复杂。
- 认证复杂,每个服务都需要独立认证。
- 难以重构,随着项目的迭代,可能需要重新划分微服务。例如,可能将多个服务合并成一个或者将一个服务拆分成多个。如果客户端直接与微服务通信,那么重构将会很难实施。
- 某些微服务可能使用了防火墙 / 浏览器不友好的协议,直接访问会有一定的困难。
以上这些问题可以借助 api 网关解决。api 网关是介于客户端和服务器端之间的中间层,所有的外部请求都会先经过 api 网关这一层。也就是说,api 的实现方面更多的考虑业务逻辑,而安全、性能、监控可以交由 api 网关来做,这样既提高业务灵活性又不缺安全性。
使用 api 网关后的优点如下:
- 易于监控。可以在网关收集监控数据并将其推送到外部系统进行分析。
- 易于认证。可以在网关上进行认证,然后再将请求转发到后端的微服务,而无须在每个微服务中进行认证。
- 减少了客户端与各个微服务之间的交互次数。
spring cloud gateway的特征
- java 8
- spring framework 5
- spring boot 2
- 动态路由
- 内置到spring handler映射中的路由匹配
- 基于http请求的路由匹配 (path, method, header, host, etc…)
- 过滤器作用于匹配的路由
- 过滤器可以修改下游http请求和http响应 (add/remove headers, add/remove parameters, rewrite path, set path, hystrix, etc…)
- 通过api或配置驱动
- 支持spring cloud discoveryclient配置路由,与服务发现与注册配合使用
快速上手
spring cloud gateway 网关路由有两种配置方式:
在配置文件 yml 中配置
通过@bean自定义 routelocator,在启动主类 application 中配置
这两种方式是等价的,建议使用 yml 方式进配置。
1.pom.xml maven依赖
<parent> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-parent</artifactid> <version>2.1.7.release</version> <relativepath/> <!-- lookup parent from repository --> </parent> <dependencymanagement> <dependencies> <dependency> <groupid>org.springframework.cloud</groupid> <artifactid>spring-cloud-dependencies</artifactid> <version>greenwich.release</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencymanagement> <dependencies> <!--spring cloud gateway 是使用 netty+webflux 实现因此不需要再引入 web 模块--> <dependency> <groupid>org.springframework.cloud</groupid> <artifactid>spring-cloud-starter-gateway</artifactid> </dependency> </dependencies> <build> <plugins> <plugin> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-maven-plugin</artifactid> </plugin> </plugins> </build>
2.application.yml配置
server: port: 8080 spring: cloud: gateway: routes: - id: easy_route # 我们自定义的路由 id,保持唯一 uri: https://github.com # 目标服务地址 predicates: # 路由条件,predicate 接受一个输入参数,返回一个布尔值结果。该接口包含多种默认方法来将 - path=/smltq/spring-boot-demo
上面这段配置的意思是,配置了一个 id 为 easy_route 的路由规则,当访问地址 http://localhost:8080/smltq/spring-boot-demo时会自动转发到地址: 。
3.配置完成启动项目
在浏览器访问进行测试,当我们访问 http://localhost:8080/smltq/spring-boot-demo 时会展示如下页面:
资料
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: PHP操作XML中XPath的应用示例
推荐阅读
-
Spring Cloud Gateway 服务网关快速实现解析
-
spring cloud config 配置中心快速实现过程解析
-
Nacos快速入门(三):Spring Cloud Alibaba Nacos实现服务注册与发现
-
Spring Cloud gateway 网关服务 一
-
Spring Cloud实战 - API网关Gateway详解实现
-
spring cloud gateway网关路由分配代码实例解析
-
spring cloud 入门系列六:使用Zuul 实现API网关服务
-
Spring Cloud Gateway服务网关
-
spring cloud gateway整合sentinel实现网关限流
-
【Spring Cloud】服务网关 gateway 工作原理