本文主要是介绍Spring Cloud全解析:网关之GateWay简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
GateWay简介
由于zuul升级为zuul2时,netflix公司内部出现了分歧,所以springcloud自己研发了一套网关gateway,提供一种简单有效的方式来对API进行路由,以及提供一些强大的过滤器功能,如:熔断、限流、重试等,基于WebFlux框架实现的,底层使用了高性能的Reactor模式通信框架Netty
特性
- 基于spring5和springboot2构建
- 动态路由:能够匹配任何请求属性
- 可以对路由指定断言和过滤器
- 集成Hystrix断路器功能
- 集成springcloud服务发现功能
- 请求限流
- 支持路径重写
GateWay内部
路由Route
路由是构建网关的基本模块,由ID、目标URI,一系列的断言和过滤器组成,如果断言为true则匹配该路由
断言Predicate
开发人员可以匹配HTTP请求中的所有内容,包括请求头和请求参数,如果请求与断言相匹配,则进行路由
过滤Filter
使用过滤器可以在请求被路由前或后进行过滤
依赖
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
主启动类
@SpringBootApplication
@EnableEurekaClient
public class GatewayApp {public static void main(String[] args) {SpringApplication.run(GatewayApp.class,args);}
}
配置
静态路由,给出确切的路由地址进行匹配
spring:application:name: springcloud2-gatewaycloud:gateway: #gateway网关配置routes:- id: springcloud2-provider-route #路由id,唯一uri: http://localhost:8001 #匹配后进行访问的路由地址predicates: # 断言,路径进行匹配才会进行路由- Path=/dept/**
动态路由,根据微服务名称进行匹配
spring:application:name: springcloud2-gatewaycloud: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简介/
这篇关于Spring Cloud全解析:网关之GateWay简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!