Spring Boot Zuul 代理服务器和路由

  • Zuul Server

    Zuul Server是一个网关应用程序,它处理所有请求并进行微服务应用程序的动态路由。Zuul服务器也称为Edge服务器。
    例如,/api/user映射到用户服务,/api/products映射到产品服务,并且Zuul Server将请求动态路由到相应的后端应用程序。在本章中,我们将详细介绍如何在Spring Boot中创建Zuul Server应用程序。
  • 创建Zuul服务器应用程序

    Zuul服务器与Spring Cloud依赖关系捆绑在一起。您可以从Spring Initializer页面https://start.spring.io/下载Spring Boot项目,然后选择Zuul Server依赖项。
    在主Spring Boot应用程序上添加@EnableZuulProxy注解。@EnableZuulProxy注解用于使您的Spring Boot应用程序充当Zuul代理服务器。
    
    package com.jc2182.demo;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.netflix.zuul.EnableZuulProxy;
    
    @SpringBootApplication
    @EnableZuulProxy
    public class ZuulserverApplication {
       public static void main(String[] args) {
          SpringApplication.run(ZuulserverApplication.class, args);
       }
    }
    
    您将必须在我们的构建配置文件中添加Spring Cloud Starter Zuul依赖项。
    Maven用户将必须在pom.xml文件中添加以下依赖项-
    
    <dependency>
       <groupId>org.springframework.cloud</groupId>
       <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
    </dependency>
    
    Gradle用户依赖的代码如下
    
    implementation 'org.springframework.cloud:spring-cloud-starter-netflix-zuul'
    
    对于Zuul路由,请在application.properties文件或application.yml文件中添加以下属性。
    
    spring.application.name = zuulserver
    zuul.routes.products.path = /api/demo/**
    zuul.routes.products.url = http://localhost:8080/
    server.port = 8111
    
    这意味着对/api/demo/的 http 请求将转发到产品服务。例如,/api/demo/products被转发到/products。
    yaml文件用户可以使用下面显示的application.yml文件-
    
    server:
       port: 8111
    spring:
       application:  
          name: zuulserver
    zuul:
    
    routes:
       products:
          path: /api/demo/**
          url: http://localhost:8080/
    
    - 在通过Zuul代理进行路由之前,http://localhost:8080/应用程序应该已经在运行。
    整个配置文件如下。
    Maven pom.xml
    
    <?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.3.0.BUILD-SNAPSHOT</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>com.jc2182</groupId>
        <artifactId>demo</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>demo</name>
        <description>Demo project for Spring Boot</description>
    
        <properties>
            <java.version>1.8</java.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
            </dependency> 
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
                <exclusions>
                    <exclusion>
                        <groupId>org.junit.vintage</groupId>
                        <artifactId>junit-vintage-engine</artifactId>
                    </exclusion>
                </exclusions>
            </dependency>
     
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    
        <repositories>
            <repository>
                <id>spring-milestones</id>
                <name>Spring Milestones</name>
                <url>https://repo.spring.io/milestone</url>
            </repository>
            <repository>
                <id>spring-snapshots</id>
                <name>Spring Snapshots</name>
                <url>https://repo.spring.io/snapshot</url>
                <snapshots>
                    <enabled>true</enabled>
                </snapshots>
            </repository>
        </repositories>
        <pluginRepositories>
            <pluginRepository>
                <id>spring-milestones</id>
                <name>Spring Milestones</name>
                <url>https://repo.spring.io/milestone</url>
            </pluginRepository>
            <pluginRepository>
                <id>spring-snapshots</id>
                <name>Spring Snapshots</name>
                <url>https://repo.spring.io/snapshot</url>
                <snapshots>
                    <enabled>true</enabled>
                </snapshots>
            </pluginRepository>
        </pluginRepositories>
    
    </project>
    
    Gradle 用户 – build.gradle
    
    plugins {
        id 'org.springframework.boot' version '2.3.0.BUILD-SNAPSHOT'
        id 'io.spring.dependency-management' version '1.0.9.RELEASE'
        id 'java'
    }
    
    group = 'com.jc2182'
    version = '0.0.1-SNAPSHOT'
    sourceCompatibility = '1.8'
    
    repositories {
        mavenCentral()
        maven { url 'https://repo.spring.io/milestone' }
        maven { url 'https://repo.spring.io/snapshot' }
    }
    
    ext {
        set('springCloudVersion', "Hoxton.BUILD-SNAPSHOT")
    }
    
    dependencies { 
        implementation 'org.springframework.cloud:spring-cloud-starter-netflix-zuul'
        testImplementation('org.springframework.boot:spring-boot-starter-test') {
            exclude group: 'org.junit.vintage', module: 'junit-vintage-engine'
        }
    }
    
    dependencyManagement {
        imports {
            mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
        }
    }
    
    test {
        useJUnitPlatform()
    }
    
    您可以创建一个可执行的JAR文件,并使用以下Maven或Gradle命令运行Spring Boot应用程序-
    对于Maven,请使用以下命令
    
    mvn clean install
    
    在“BUILD SUCCESS”之后,您可以在target目录下找到JAR文件。
    对于Gradle,请使用以下命令-
    
    gradle clean build
    
    在“BUILD SUCCESSFUL”之后,您可以在build/libs目录下找到JAR文件。
    现在,使用如下所示的命令运行JAR文件:
    
    java –jar <JARFILE>
    
    您会发现该应用程序已在Tomcat端口8111上启动。
    现在,在Web浏览器中访问URL http://localhost:8111/api/demo/products,您可以看到/products REST Endpoint 的输出,如下所示-