0%

GateWay简介

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: #gateway网关配置
routes:
- id: springcloud2-provider-route #路由id,唯一
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: #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