快速搭建spring-cloud-gateway
网关概述:
• 网关旨在为微服务架构提供一种简单而有效的统一的API路由管理方式。
• 在微服务架构中,不同的微服务可以有不同的网络地址,各个微服务之间通过互相调用完成用户请求,客户 端可能通过调用N个微服务的接口完成一个用户请求。
• 存在的问题:
• 客户端多次请求不同的微服务,增加客户端的复杂性
• 认证复杂,每个服务都要进行认证
• http请求不同服务次数增加,性能不高
• 网关就是系统的入口,封装了应用程序的内部结构,为客户端提 供统一服务,一些与业务本身功能无关的公共 逻辑可以在这里实现, 诸如认证、鉴权、监控、缓存、负载均衡、流量管控、路由转发等
• 在目前的网关解决方案里,有Nginx+ Lua、Netflix Zuul 、Spring Cloud Gateway等等
网关的快速入门
1、搭建网关模块
2、引入依赖:
<dependencies>
<!--引入gateway 网关-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<!-- eureka-client -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
3、编写启动类
package com.itheima.gateway;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
@SpringBootApplication
@EnableEurekaClient
public class ApiGatewayApp {
public static void main(String[] args) {
SpringApplication.run(ApiGatewayApp.class,args);
}
}
4、编写配置文件
静态路由配置
server:
port: 80 #默认的是80端口
spring:
application:
name: api-gateway-server
cloud:
#网关的配置
gateway:
#路由配置:转发规则
routes: #是集合
#唯一标识。默认是uuid
- id: gateway-provider #提供者的模块名
#静态路由
#转发路径
uri: http://localhost:8001 #提供者的默认端口
#动态路由
predicates: #条件,用于请求网关路径的匹配规则
- Path=/goods/**
然后访问提供者的路径(自己写的demo)
没加网关前访问的地址是
加网关后的访问地址
动态路由配置
静态路由配置一般在项目中不建议使用,下面展示一下动态路由的配置
server:
port: 80
spring:
application:
name: api-gateway-server
cloud:
#网关的配置
gateway:
#路由配置:转发规则
routes: #集合
#唯一标识。默认是uuid
- id: gateway-provider
#静态路由
#转发路径
#uri: http://localhost:8001
#动态路由
uri: lb://GATEWAY-PROVIDER #转发条件
predicates: #条件,用于请求网关路径的匹配规则
- Path=/goods/**
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka
uri 换成注册中心的服务名称,就不需要再去写路径加端口
这时候再去访问http://localhost/goods/findOne/2,会发现还是能够访问的这句说明我们动态路由配置成功了
微服务名称配置
这时大家肯定疑惑那我访问路径的时候怎么去判断我访问的是哪个服务的地址
这里我们设置微服务名称配置,大家访问的时候就会清晰明了
cloud:
#网关的配置
gateway:
#路由配置:转发规则
routes: #集合
#唯一标识。默认是uuid
- id: gateway-provider
#静态路由
#转发路径
#uri: http://localhost:8001
#动态路由
uri: lb://GATEWAY-PROVIDER #转发条件
predicates: #条件,用于请求网关路径的匹配规则
- Path=/goods/**
filters:
- AddRequestParameter=username,zhangsan
- id: gateway-consumer
#静态路由
# uri: http://localhost:9000
#动态路由
uri: lb://GATEWAY-CONSUMER
predicates:
- Path=/order/**
# 微服务名称配置
discovery:
locator:
enabled: true
lower-case-service-id: true
这个时候我们再去访问一下,这里我们在原来的访问路径上再加上 gateway-provider访问也是可以的
加不加gateway-provider都能访问,大家可以试试。
网关过滤器
• Gateway 支持过滤器功能,对请求或响应进行拦截,完成一些通用 操作。
• Gateway 提供两种过滤器方式:“pre”和“post”
• pre 过滤器,在转发之前执行,可以做参数校验、权限校验、流量监 控、日志输出、协议转换等。
• post 过滤器,在响应之前执行,可以做响应内容、响应头的修改, 日志的输出,流量监控等。
• Gateway 还提供了两种类型过滤器
• GatewayFilter:局部过滤器,针对单个路由
• GlobalFilter :全局过滤器,针对所有路由
gateway过滤器—局部过滤器
• GatewayFilter 局部过滤器,是针对单个路由的过滤器。
• 在Spring Cloud Gateway 组件中提供了大量内置的局部过滤器,对 请求和响应做过滤操作。
• 遵循约定大于配置的思想,只需要在配置文件配置局部过滤器名称, 并为其指定对应的值,就可以让其生效
gateway过滤器—全局过滤器
GlobalFilter 全局过滤器,不需要在配置文件中配 置,系统初始化时加载,并作用在每个路由上。
• Spring Cloud Gateway 核心的功能也是通过内置 的全局过滤器来完成。
• 自定义全局过滤器步骤:
- 定义类实现 GlobalFilter 和 Ordered接口
- 复写方法
- 完成逻辑处理
给大家附上gateway内置过滤器的详解:https://blog.csdn.net/weixin_44984726/article/details/116293680
上。
• Spring Cloud Gateway 核心的功能也是通过内置 的全局过滤器来完成。
• 自定义全局过滤器步骤:
- 定义类实现 GlobalFilter 和 Ordered接口
- 复写方法
- 完成逻辑处理
给大家附上gateway内置过滤器的详解:https://blog.csdn.net/weixin_44984726/article/details/116293680