前言——什么是网关
API 网关是一个搭建在客户端和微服务之间的服务,我们可以在 API 网关中处理一些非业务功能的逻辑,例如权限验证、监控、缓存、请求路由等。
API 网关就像整个微服务系统的门面一样,是系统对外的唯一入口。有了它,客户端会先将请求发送到 API 网关,然后由 API 网关根据请求的标识信息将请求转发到微服务实例。
一,使用网关的优点
1.客户端通过 API 网关与微服务交互时,客户端只需要知道 API 网关地址即可,而不需要维护大量的服务地址,简化了客户端的开发。
2.客户端直接与 API 网关通信,能够减少客户端与各个服务的交互次数。
3.客户端与后端的服务耦合度降低。
二,GateWay网关介绍
gateway网关是众多网关api中的一种高效能api网关
Spring Cloud GateWay 最主要的功能就是路由转发,而在定义转发规则时主要涉及了以下三个核心概念。
1.路由:网关最基本模块,是有一个id,一个目标地址uri,一组断言,一组过滤器组成
2.断言:判断传来的请求的地址,请求头,请求类型等,从而转发到相应的服务
3.过滤:对传来的请求进行修改和过滤
三,项目如何使用
3.1 添加依赖
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-webflux</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
</dependencies>
注意:应为gateway是基于netty的,一定要把spring-boot-starter-web依赖换成spring-boot-starter-webflux
3.2 添加yaml配置文件
spring:
application:
name: skr-hello
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
gateway:
routes:
- id: test #唯一
uri: lb://skr-hello #对应要匹配的服务名称,lb的意思,就是从注册中心获取,后面才可以跟服务的名称
predicates:
- Path=/test/** #外界的访问路径
filters:
- StripPrefix=1 #过滤器,去除访问的1个路径
访问 http://localhost:8080/test/api/hello/hi 时,经过 Gateway 的路由和过滤器处理后,实际请求的 URI 会是:http://skr-hello/api/hello/hi