一、SpringCloud版本
本文介绍的Springboot版本为2.1.1.RELEASE,SpringCloud版本为Greenwich.RC1,JDK版本为1.8,集成环境为IntelliJ IDEA
二、zuul介绍
路由在微服务体系结构的一个组成部分。例如,/可以映射到您的Web应用程序,/api/users映射到用户服务,并将/api/shop映射到商店服务。Zuul是Netflix的基于JVM的路由器和服务器端负载均衡器。
Netflix使用Zuul进行以下操作:
- 认证
- 洞察
- 压力测试
- 金丝雀测试
- 动态路由
- 服务迁移
- 负载脱落
- 安全
- 静态响应处理
- 主动/主动流量管理
Zuul的规则引擎允许基本上写任何JVM语言编写规则和过滤器,内置Java和Groovy。
要在您的项目中包含Zuul,请使用组org.springframework.cloud和spring-cloud-starter-netflix-zuul的启动器。
三、创建zuul服务
- 3.1创建
创建一个module,取名为cloudzuul,选择Cloud Routing,再勾选上Zuul,完成
创建完成的pom文件,可以看到spring-cloud-starter-netflix-zuul依赖
<?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.jthao</groupId>
<artifactId>cloudzuul</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>cloudzuul</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>com.jthao</groupId>
<artifactId>cloudser</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
</project>
- 3.2启动
在启动类上增加@EnableZuulProxy,开启zuul代理功能
package com.jthao.cloudzuul;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;
@EnableZuulProxy
@EnableDiscoveryClient
@SpringBootApplication
public class CloudzuulApplication {
public static void main(String[] args) {
SpringApplication.run(CloudzuulApplication.class, args);
}
}
修改配置文件,设置端口8006,服务名cloudzuul,配置服务注册中心
其中zuul.routes.api-a.path
和zuul.routes.api-a.service-id
是将所有/api-a/请求都转发给cloudcustomer服务,同理在此处也可增加api-b.path和api-b.service-id来设置所有请求都转发给cloudribbon
server.port=8006
spring.application.name=cloudzuul
eureka.client.service-url.defaultZone: http://localhost:8001/eureka/
zuul.routes.api-a.service-id=cloudcustomer
zuul.routes.api-a.path=/api-a/**
- 3.3访问
启动cloudser和两个cloudclient服务,cloudclient服务端口分别8002,8003
启动zuul服务
通过浏览器多次访问http://localhost:8006//api-a/test?name=zull
我们可以看到如下展示
zull===端口:8002被调用了===
zull===端口:8003被调用了===