SpringCloud(四)Gateway路由
最初的想法,是将Gateway与注册中心整合,并成一个工程,实际操作后发现不行。
1、Gateway 与 spring-boot-starter-web 包冲突,Gateway 明确声明,需要清除 spring-boot-starter-web 依赖,
2、在与Server整合后,出现代码不兼容的情况,部分Class无法找到,无法启动项目。
既然如此,还是遵循惯例优先原则,尽可能地选择默认配置,不去过分改动原本的设计。
完成本章节的内容,就已经完成了SpringCloud的基本配置,因为已经能够支持项目允许,暂时不想继续深入研究。
本次编码的目的,是为了统一程序入口,通过一个端口,可以访问所有的服务,方便后续的鉴权、授权等功能。
简单介绍一些我们用到的几个东西
EurekaServer:相当于Spring容器,可以托管我们所有的服务;
EurekaClient:相当于一个个Class,每一个EurekaClient需要放置到容器中,统一管理起来;
Feign:相当于Spring中的@Resource注解,每一个EurekaClient引用其它服务的时候,需通过Feign引用;
Hystrix:熔断降级,相当于Spring中的异常切面,网络不通了,其它服务调用不起来了,此时需要提供有损服务;
Gateway:路由,相当于DispatcherServlet,提供统一的程序入口,每一个请求都走这个接口,然后分发到特定的服务上。
Maven依赖
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.13.RELEASE</version> <relativePath/> </parent> <groupId>cn.seaboot</groupId> <artifactId>gateway</artifactId> <version>0.0.1-SNAPSHOT</version> <name>gateway</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> <spring-cloud.version>Greenwich.SR5</spring-cloud.version> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-gateway</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-hystrix</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>${spring-cloud.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
Yml配置
最核心代码就是下面的配置,如果采用默认配置,不需要写任何代码就能实现。
下面这段代码,除了开启 Gateway 功能之外,还向 eureka 注册了 Gateway服务。
server:
port: 8760
spring:
application:
name: api-gateway
# 开启 Gateway 服务注册中心服务发现
cloud:
gateway:
discovery:
locator:
enabled: true
# 向 eureka 注册当前服务
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka/
Java代码
package cn.seaboot.gateway; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.gateway.route.RouteLocator; import org.springframework.cloud.gateway.route.builder.RouteLocatorBuilder; import org.springframework.context.annotation.Bean; /** * @author Mr.css */ @SpringBootApplication public class GatewayApplication { public static void main(String[] args) { SpringApplication.run(GatewayApplication.class, args); } @Bean public RouteLocator myRoutes(RouteLocatorBuilder builder) { // 常见的demo,并不是必须的配置,这里只是做展示,这个demo用于拦截get请求,往请求头添加一个参数,然后转到http://httpbin.org:80 return builder.routes() .route(p -> p .path("/get") .filters(f -> f.addRequestHeader("Hello", "World")) .uri("http://httpbin.org:80")) .build(); // return builder.routes() // .route(p -> p // .path("/get") // .filters(f -> f.addRequestHeader("Hello", "World")) // .uri("http://httpbin.org:80")) // .build(); } }
效果如下:
CLIENT-A是我们前面文章中写好的Demo,访问接口 http://localhost:8760/CLIENT-A/hi ,通过服务名即可访问页面,效果如下: