基础配置
网关作为一个单独的微服务,其作用是在负载均衡和微服务提供者之间起到保护、限流作用。
其配置的依赖如下:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
注意,这里配置不需要配置web依赖,否则会报错。
在application.yml配置如下:
server:
port: 9527
spring:
application:
name: cloud-gateway
cloud:
gateway:
routes:
- id: payment_route # 路由的id,没有规定规则但要求唯一,建议配合服务名
uri: http://localhost:8001
predicates:
- Path=/payment/discovery/** # 断言,路径相匹配的进行路由
- id: payment_route2
uri: http://localhost:8001
predicates:
Path=/payment/lb/** #断言,路径相匹配的进行路由
eureka:
instance:
hostname: cloud-gateway-service
client:
fetch-registry: true
register-with-eureka: true
service-url:
defaultZone: http://eureka7001.com:7001/eureka/
配置动态路由
篇日志动态路由好处就是可以方面扩展微服务,同时在网关处配置动态路由可以实现负载均衡。之前的负载均衡都是由Ribbon的@LoadBalance实现。现在由网关实现。仅配置yml文件即可。
server:
port: 9527
spring:
application:
name: cloud-gateway
cloud:
gateway:
discovery:
locator:
enabled: true
routes:
- id: payment_route # 路由的id,没有规定规则但要求唯一,建议配合服务名
uri: lb://CLOUD-PAYMENT-SERVICE
predicates:
- Path=/payment/discovery/** # 断言,路径相匹配的进行路由
- id: payment_route2
uri: lb://CLOUD-PAYMENT-SERVICE
predicates:
Path=/payment/lb/** #断言,路径相匹配的进行路由
eureka:
instance:
hostname: cloud-gateway-service
client:
fetch-registry: true
register-with-eureka: true
service-url:
defaultZone: http://eureka7001.com:7001/eureka/
在这里配置了打开discovery的locator,即动态路由功能。之后在配置具体uri为微服务名。动态路由即配置完成。
predicates断言设置
- After=2017-01-20T17:42:47.789-07:00[America/Denver]
- Before=2017-01-20T17:42:47.789-07:00[America/Denver]
- Cookie=username,zzyy
- Header=X-Request-Id, \d+ #请求头要有X-Request-Id属性,并且值为正数
- Host=**.atguigu.com
- Method=GET
- Query=username, \d+ # 要有参数名username并且值还要是正整数才能路由
filter过滤器
指的是Spring框架中GatewayFilter的实例,使用过滤器,可以在请求被路由前或者之后对请求进行修改.
生命周期
仅分为两种,pre和post。意思是在路由之前和路由之后
种类
GatewayFilter 具体配置
GlobalFilter 具体配置