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