• SpringCloud(四)Gateway请求转发


    最初的想法,是将Gateway与注册中心整合,并成一个工程,实际操作后发现不行。
    1、Gateway 与 spring-boot-starter-web 包冲突,Gateway 明确声明,需要清除 spring-boot-starter-web 依赖,
    2、在与Server整合后,出现代码不兼容的情况,部分Class无法找到,无法启动项目。

    既然如此,还是遵循惯例优先原则,尽可能地选择默认配置,不去过分改动原本的设计。

    完成本章节的内容,就已经完成了SpringCloud的基本。后续的代码主要看实际业务需求,使用框架,能帮助我们节省大量的代码,但是,不通过框架也可以自己编码解决,并没有太多的硬性规定。

    本次编码的目的,是为了统一程序入口,通过一个端口,可以访问所有的服务,方便后续的鉴权、授权等功能。

    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配置

    实际上,需要的配置就下面几行

    server:
      port: 8760
    spring:
      application:
        name: api-gateway
      # 开启 Gateway 服务注册中心服务发现
      cloud:
        gateway:
          discovery:
            locator:
              enabled: true
    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,拦截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();
      }
    }

    效果如下:

    访问接口 http://localhost:8760/CLIENT-A/hi ,通过服务名即可访问页面,效果如下:

  • 相关阅读:
    Github Actions 中 Service Container 的使用
    EFCore 5 新特性 SaveChangesInterceptor
    使用 Xunit.DependencyInjection 改造测试项目
    WeihanLi.Npoi 1.11.0/1.12.0 Release Notes
    新版本 swagger 组件中 Servers 的 坑
    JDBC 规范中文版 4.2- 第五章 类和接口
    JDBC 规范中文版 4.2 -第四章 概览
    JDBC 规范中文版 4.2 -第三章 新特性
    JDBC 规范中文版 4.2 -第二章 目标
    Serve static assets with an efficient cache policy
  • 原文地址:https://www.cnblogs.com/chenss15060100790/p/12638130.html
Copyright © 2020-2023  润新知