GateWay简介
由于zuul升级为zuul2时,netflix公司内部出现了分歧,所以springcloud自己研发了一套网关gateway,提供一种简单有效的方式来对API进行路由,以及提供一些强大的过滤器功能,如:熔断、限流、重试等,基于WebFlux框架实现的,底层使用了高性能的Reactor模式通信框架Netty
特性
- 基于spring5和springboot2构建
- 动态路由:能够匹配任何请求属性
- 可以对路由指定断言和过滤器
- 集成Hystrix断路器功能
- 集成springcloud服务发现功能
- 请求限流
- 支持路径重写
GateWay内部
路由Route
路由是构建网关的基本模块,由ID、目标URI,一系列的断言和过滤器组成,如果断言为true则匹配该路由
断言Predicate
开发人员可以匹配HTTP请求中的所有内容,包括请求头和请求参数,如果请求与断言相匹配,则进行路由
过滤Filter
使用过滤器可以在请求被路由前或后进行过滤
依赖
xml
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
主启动类
java
@SpringBootApplication
@EnableEurekaClient
public class GatewayApp {
public static void main(String[] args) {
SpringApplication.run(GatewayApp.class,args);
}
}
配置
静态路由,给出确切的路由地址进行匹配
yml
spring:
application:
name: springcloud2-gateway
cloud:
gateway: #gateway网关配置
routes:
- id: springcloud2-provider-route #路由id,唯一
uri: http://localhost:8001 #匹配后进行访问的路由地址
predicates: # 断言,路径进行匹配才会进行路由
- Path=/dept/**
动态路由,根据微服务名称进行匹配
yml
spring:
application:
name: springcloud2-gateway
cloud:
gateway: #gateway网关配置
routes:
- id: springcloud2-provider-route #路由id,唯一
# uri: http://localhost:8001 #匹配后进行访问的路由地址,直接指定访问地址
uri: lb://springcloud2-provider #使用负载均衡,根据微服务名称进行负载
predicates: # 断言,路径进行匹配才会进行路由
- Path=/dept/**
discovery:
locator:
enabled: true #开启从注册中心动态创建路由的功能,利用微服务名称进行路由
# eureka 配置
eureka:
client: # 注册到eureka server注册中心
service-url:
defaultZone: http://localhost:7001/eureka # eureka server提供的注册地址
instance:
instance-id: springcloud2-gateway # 服务实例名称,在eureka server页面中的status列中
prefer-ip-address: true # 访问路径显示ip
https://zhhll.icu/2021/框架/微服务/springcloud/网关/GateWay/1.GateWay简介/