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 ,通过服务名即可访问页面,效果如下:

 

posted on 2020-04-05 17:28  疯狂的妞妞  阅读(13698)  评论(0编辑  收藏  举报

导航