目录
Gateway 整合 Eureka 路由转发
创建一个 module 模块 blog-spring-cloud-gateway,然后添加依赖增加 Spring Cloud Gateway 的依赖,代码如下所示:
<!-- spring-gateway -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
启动类就按 Spring Boot 的方式即可,无须添加额外的注解。代码如下所示:
@SpringBootApplication
public class BlogGatewayApplication {
public static void main(String[] args) {
SpringApplication.run(BlogGatewayApplication.class, args);
}
}
下面来实现一个最简单的转发功能——基于 Path 的匹配转发功能。
Gateway 的路由配置对 yml 文件支持比较好,我们在 resources 下建一个 application.yml
的文件,内容如下:
spring:
application:
name: blog-spring-cloud-gateway
cloud:
gateway:
routes:
- id: stary-study-route
uri: https://stary1993.com.cn/
predicates:
- Path=/study/**
server:
port: 8011
这样一来,上面的配置就可以支持多级 Path,比如访问 http://localhost:8011/study/index.html 的时候就会转发到 https://stary1993.com.cn/study/index.html 。
添加 Eureka Client 的依赖,代码如下所示:
<!-- eureka-client -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
配置基于 Eureka 的路由:
- id: blog-user-web-route
uri: lb://blog-user-web
predicates:
- Path=/user/**
uri 以lb://
开头(lb 代表从注册中心获取服务),后面接的就是你需要转发到的服务名称,这个服务名称必须跟 Eureka 中的对应,否则会找不到服务。
Zuul 默认会为所有服务都进行转发操作,我们只需要在访问路径上指定要访问的服务即可,通过这种方式就不用为每个服务都去配置转发规则,当新加了服务的时候,不用去配置路由规则和重启网关。
在 Spring Cloud Gateway 中当然也有这样的功能,通过配置即可开启,配置如下:
spring:
cloud:
gateway:
discovery:
locator:
enabled: true
开启之后我们就可以通过地址去访问服务了,格式如下:
http://网关地址/服务名称(大写)/**
http://localhost:8011/BLOG-USER-WEB/user/query/1
这个大写的名称还是有很大的影响,如果我们从 Zuul 升级到 Spring Cloud Gateway 的话意味着请求地址有改变,或者重新配置每个服务的路由地址,通过源码发现可以做到兼容处理,再增加一个配置即可:
spring:
cloud:
gateway:
discovery:
locator:
enabled: true
lower-case-service-id: true
配置完成之后我们就可以通过小写的服务名称进行访问了,如下所示:
http://网关地址/服务名称(小写)/**
http://localhost:8011/blog-user-web/user/query/1
注意:开启小写服务名称后大写的服务名称就不能使用,两者只能选其一。