gateway简介
Spring Cloud Gateway 的目标,不仅提供统一的路由方式,并且基于 Filter 链的方式提供了网关基本的功能,例如:安全,监控/指标,和限流。
特征:
(1)基于 Spring Framework 5,Project Reactor 和 Spring Boot 2.0
(2)集成 Hystrix 断路器
(3)集成 Spring Cloud DiscoveryClient
(4)Predicates 和 Filters 作用于特定路由,易于编写的 Predicates 和 Filters
(5)具备一些网关的高级功能:动态路由、限流、路径重写
gateway简单实现
- 搭建项目
添加依赖
- 增加路由配置
修改application.yaml
server:
port: 80
spring:
application:
name: gateway
cloud:
gateway:
enabled: true # 只要加了依赖,默认开启
routes:
- id: login-server-route # 路由id,保持唯一即可
uri: http://localhost:8020
predicates:
- Path=/login # 匹配规则, 匹配的路由向uri转发
- 搭建login服务
新建spring web项目
server.port=8020
spring.application.name=login
- 查看界面
login路径的请求成功转发到了8020端口,并返回了请求
- 代码路由
@Configuration
public class RouteConfig {
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
return builder.routes().route("login2", r -> r.path("/login2").uri("http://localhost:8020")).build();
}
}
- 界面展示
- 动态路由
以上方式可以实现静态路由,但是会有两个问题
- 如果一个服务新增接口怎么办,难道每次都要修改yaml配置吗
- 在分布式系统里,怎么做服务发现
为了解决上述两个问题,我们需要和服务发现结合起来,做动态路由
- 将Gateway服务和login服务都注册到Eureka
- 开启Gateway服务动态路由
server:
port: 80
spring:
application:
name: gateway
cloud:
gateway:
enabled: true # 只要加了依赖,默认开启
discovery:
locator:
enabled: true # 开启动态路由 开启通用名称路由
lower-case-service-id: true # 开启服务名称小写
eureka:
client:
service-url:
defaultZone: http://test1:8671/eureka
- 界面展示
请求服务localhost/service-name/uri