Zuul作为路由网关组件,在微服务架构当中有着非常重要的作用,主要体现在6个方面:
- Zuul,Ribbon以及Eureka相结合,可以实现智能路由和负载均衡的功能,Zuul能够将请求流量按某种策略分发到集群状态的多个服务器实例。
- 网关将所有服务的API接口统一聚合,并统一对外暴露。外界系统调用API接口时,都是由网关对外暴露的API接口,外界系统不需要知道微服务系统当中各服务相互调用的复杂性。也保护了内部微服务单元的API接口,防止外界直接调用,导致服务的敏感信息对外暴露。
- 网关服务可以做用户身份认证和权限验证,防止非法请求操作API接口,对服务器起到保护作用。
- 网关可以实现监控功能,实时日志输出,对请求进行记录。
- 网关可以实现流量监控,在高流量的情况下,对服务器进行降级。
- API接口从内部服务分离出来,方便做测试。
案例:基于上一篇文章的项目体系。
创建新的子模块(module):cloud-zuul
pom文件:
<?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">
<parent>
<artifactId>cloud-demo</artifactId>
<groupId>spring-cloud-demo</groupId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>cloud-zuul</artifactId>
<name>cloud-zuul</name>
<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>
</dependencies>
</project>
application.yml:配置路由等信息
server:
port: 8092
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
spring:
application:
name: cloud-zuul
zuul:
routes:
ribbon:
path: /ribbon/**
serviceId: service-consumer
feign:
path: /feign/**
serviceId: client-feign
启动类:
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;
@SpringBootApplication
@EnableEurekaClient
@EnableZuulProxy
public class ZuulApplication {
public static void main(String[] args) {
SpringApplication.run(ZuulApplication.class, args);
}
}
测试:开启所有相关服务,访问:
该链接会根据路由配置的信息找到对应的服务进行调用。