目录
1 概述
Zuul是Netflix开源的微服务网关,SpringCloud进行了集成,能够非常方便地与Eureka、Ribbon等组件集成。
本篇拟采用Zuul搭建一个简单的微服务网关。
2 构建Zuul服务网关
2.1 构建gateway项目
因为我们要将gateway注册到服务中心,因此构建项目时,选择Eureka Client和Zuul依赖,如下所示:
创建成功后,pom.xml会包含如下两个选择的依赖:
<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-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
编写application.yml配置文件,如下:
server:
port: 8020
spring:
application:
name: gateway
eureka:
client:
service-url:
defaultZone: http://admin:admin123@127.0.0.1:8000/eureka/
zuul:
routes:
user-ms:
path: /user/**
strip-prefix: true
role-ms:
path: /role/**
strip-prefix: true
上面zuul.routes节点的配置中,**代表通配符,表示将 /user/ 开头的请求路由至user-ms微服务,将 /role/ 开头的请求路由至role-ms微服务。
2.2 路由配置示例
Zuul支持多种方式的路由配置,如下所示(参考自:《Spring Cloud与Docker微服务架构实战》):
1. 定义指定服务的访问路径
zuul:
routes:
user-ms: /u/**
role-ms: /r/**
2. 忽略指定的服务
zuul:
ignored-services: serviceA,ServiceB
3. 忽略所有服务
zuul:
ignored-services: '*'
4. 指定服务的serviceId和路径
zuul:
routes:
user: # 服务别名,可任意起名
service-id: user-ms
path: /u/**
5. 指定url和路径
zuul:
routes:
github:
path: /github/**
url: https://github.com/GreedyStar
6. 路由前缀
zuul:
routes:
user-ms:
path: /user/**
strip-prefix: false
访问Zuul的 /user/1 路径,请求会转发至user-ms的/user/1
这是很常用的一种方式,在user-ms的Controller中,我们将所有请求映射至/user/路径下,在不配置strip-prefix时,我们需要请求user-ms/user/user/list 才能正确请求到user-ms的接口。
3 测试
我们可以通过gateway来访问到指定的微服务,本篇中建立的路由规则为:
Path | MicroService |
/user/** | user-ms localhost:8800 |
/role/** | role-ms localhost:8801 |
结果如下: