Zuul Server是一个网关应用程序,可处理所有请求并执行微服务应用程序的动态路由。 Zuul服务器也称为边缘服务器。
例如,/api/user映射到用户服务,/api/products映射到产品服务,Zuul Server将请求动态路由到相应的后端应用程序。
在本章中,将详细介绍如何在Spring Boot中创建Zuul Server应用程序。
创建Zuul服务器应用程序
Zuul Server捆绑了Spring Cloud依赖项。可以从Spring Initializer页面https://start.spring.io /下载Spring Boot项目,然后选择Zuul Server依赖项。
在主Spring Boot应用程序中添加@EnableZuulProxy注解。 @EnableZuulProxy注释用于使Spring Boot应用程序充当Zuul代理服务器。
package com.felix.zuulserver;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.cloud.netflix.zuul.EnableZuulProxy;@SpringBootApplication@EnableZuulProxypublic class ZuulserverApplication { public static void main(String[] args) { SpringApplication.run(ZuulserverApplication.class, args); }}
必须在构建配置文件中添加Spring Cloud Starter Zuul依赖项。
Maven用户需要在pom.xml 文件中添加以下依赖项 -
org.springframework.cloud spring-cloud-starter-zuul
对于Gradle用户,请在build.gradle 文件中添加以下依赖项 -
compile('org.springframework.cloud:spring-cloud-starter-zuul')
对于Zuul路由,请在application.properties 文件或application.yml 文件中添加以下属性。
spring.application.name = zuulserverzuul.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: 8111spring: application: name: zuulserverzuul:routes: products: path: /api/demo/** url: http://localhost:8080/
注 - 在通过Zuul Proxy进行路由之前,http://localhost:8080/应用程序应该已经运行。
完整的构建配置文件如下所示。
Maven用户可以使用下面给出的pom.xml 文件 -
<?xml version = "1.0" encoding = "UTF-8"?>4.0.0com.felix zuulserver 0.0.1-SNAPSHOTjarzuulserverDemo project for Spring Bootorg.springframework.boot spring-boot-starter-parent 1.5.9.RELEASEUTF-8UTF-81.8Edgware.RELEASEorg.springframework.cloud spring-cloud-starter-zuul org.springframework.boot spring-boot-starter-test testorg.springframework.cloud spring-cloud-dependencies ${spring-cloud.version}pomimportorg.springframework.boot spring-boot-maven-plugin
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.felix'version = '0.0.1-SNAPSHOT'sourceCompatibility = 1.8repositories { 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文件,并使用下面给出的Maven或Gradle命令运行Spring Boot应用程序 -
对于Maven,可以使用下面给出的命令 -
mvn clean install
在“BUILD SUCCESS”之后,可以在target目录下找到JAR文件。
对于Gradle,可以使用下面给出的命令 -
gradle clean build
在“BUILD SUCCESSFUL” 之后,可以在build/libs目录下找到JAR文件。
现在,使用下面显示的命令运行JAR文件 -
java –jar
在Tomcat端口8111上找到已启动的应用程序。
现在,在Web浏览器访问URL => http://localhost:8111/api/demo/products,可看到/products REST端点的输出,如下所示 -