Zuul Server — это приложение-шлюз, которое обрабатывает все запросы и выполняет динамическую маршрутизацию приложений микросервиса. Сервер Zuul также известен как пограничный сервер.
Например, / api / user сопоставляется со службой пользователя, а / api / products сопоставляется со службой продукта, а Zuul Server динамически направляет запросы в соответствующее приложение бэкэнда.
В этой главе мы подробно рассмотрим, как создать приложение Zuul Server в Spring Boot.
Создание приложения на сервере Zuul
Сервер Zuul связан с зависимостью Spring Cloud. Вы можете загрузить проект Spring Boot со страницы Spring Initializer https://start.spring.io/ и выбрать зависимость Zuul Server.
Добавьте аннотацию @EnableZuulProxy в основное приложение Spring Boot. Аннотация @EnableZuulProxy используется для того, чтобы приложение Spring Boot действовало как прокси-сервер Zuul.
package com.tutorialspoint.zuulserver; 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-zuul</artifactId> </dependency>
Для пользователей Gradle добавьте приведенную ниже зависимость в свой файл build.gradle
compile('org.springframework.cloud:spring-cloud-starter-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
Это означает, что http вызывает / api / demo / get и перенаправляется в службу продуктов. Например, / api / demo / products перенаправляется в / products .
Пользователи файла yaml могут использовать файл application.yml, показанный ниже —
server: port: 8111 spring: application: name: zuulserver zuul: routes: products: path: /api/demo/** url: http://localhost:8080/
Примечание. Приложение http: // localhost: 8080 / уже должно быть запущено до маршрутизации через Zuul Proxy.
Полный файл конфигурации сборки приведен ниже.
Пользователи 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 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.tutorialspoint</groupId> <artifactId>zuulserver</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>zuulserver</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> <spring-cloud.version>Edgware.RELEASE</spring-cloud.version> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zuul</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>
Пользователи Gradle могут использовать файл build.gradle, приведенный ниже —
buildscript { ext { springBootVersion = '1.5.9.RELEASE' } repositories { mavenCentral() } dependencies { classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}") } } apply plugin: 'java' apply plugin: 'eclipse' apply plugin: 'org.springframework.boot' group = 'com.tutorialspoint' version = '0.0.1-SNAPSHOT' sourceCompatibility = 1.8 repositories { mavenCentral() } ext { springCloudVersion = 'Edgware.RELEASE' } dependencies { compile('org.springframework.cloud:spring-cloud-starter-zuul') testCompile('org.springframework.boot:spring-boot-starter-test') } dependencyManagement { imports { mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}" } }
Вы можете создать исполняемый файл JAR и запустить приложение Spring Boot, используя команды Maven или Gradle, приведенные ниже —
Для Maven, вы можете использовать команду, приведенную ниже —
mvn clean install
После «BUILD SUCCESS» вы можете найти файл JAR в целевом каталоге.
Для Gradle вы можете использовать команду, приведенную ниже —
gradle clean build
После «BUILD SUCCESSFUL» вы можете найти файл JAR в каталоге build / libs.
Теперь запустите файл JAR с помощью команды, показанной ниже —
java –jar <JARFILE>
Вы можете найти приложение, запущенное на порту Tomcat 8111, как показано здесь.
Теперь перейдите по URL-адресу http: // localhost: 8111 / api / demo / products в вашем веб-браузере, и вы увидите выходные данные / products REST Endpoint, как показано ниже —