Zuul路由网关
1、什么是Zuul
Zuul包含了对请求的路由和过滤两个最主要的功能:
其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础,而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验,服务聚合等功能的基础。Zuul和Eureka进行整合, 将Zuu自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。
注意:Zuul服务最终还是会注册进Eureka
提供:代理+路由+过滤 三大功能
2、Zuul能干什么
- 路由
- 过滤
官网文档=> https://github.com/Netflix/zuul
3、为什么要建立Zuul
Netfix. API流量的数量和多样性有时会导致生产问题迅速出现而没有警告。我们需要一个允许我们快
速改支行为以对这些情况做出反应的系统。
Zuul使用了各种不同类型的过滤器,这使我们能够快速灵活地将功能应用于边缘服务。这些过滤器帮
助我们执行以下功能 :
- 身份验证和安全性识别每个资源的身份验证要求,井拒绝不满足要求的请求。
- 见解和监控在边缘跟族有意义的数据和统计信息,以便为我们提供准确的生产规图。
- 动态路由根据需要将请求动态路由到不同的后端群集
- 压力测试逐渐增加到群集的流量以评估性能。
- 减载-小每种类型的清求分配容量,并丢弃超出限制的请求。
- 静态响应处理-直接在边缘构建一 些响应。而不是将其转发到内部集群
- 多区域弹性在AWS区域之间路由请求,以多样化我们的ELB使用并将我们的优势拉近我们的成员有关更多详细信息:我们如何在Netfio中使用Zuul
4、Zuul组件
- zuul-core–zuul核心库,包含编译和执行过滤器的核心功能
- zuul-simple-webapp–zuul Web应用程序示例,展示了如何使用zuul-core构建应用程序
- zuul-netflix–lib包,将其他NetflixOSS组件添加到Zuul中,例如使用功能区进去路由请求处理
- zuul-netflix-webapp–webapp,它将zuul-core和zuul-netflix封装成一个简易的webapp工程包
5、Zuul路由网关 项目搭建
创建maven项目 springcloud/springcloud-zuul-9527
导入 springcloud-consumer-hystrix-dashboard
项目所有依赖,并加上Zuul依赖
<!--Zuul路由网关 9527端口-->
<artifactId>springcloud/springcloud-zuul-9527</artifactId>
<!--Zuul路由网关-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
<version>1.4.6.RELEASE</version>
</dependency>
创建application.yml,配置
server:
port: 9527
spring:
application:
name: springcloud-zuul
eureka:
client:
service-url:
defaultZone: http://localhost:7001/eureka/,http://localhost:7002/eureka/,http://localhost:7003/eureka/
instance:
#修改Eureka中status的默认描述信息。不配置默认为DESKTOP-XXX描述
instance-id: zuul9527.com #自定义名称
prefer-ip-address: true #改为true后 Eureka中的status就会显示真实ip地址
info: #链接点开后显示的info信息
app.name: tizi => zuul test
company.name: tizi=> zuul.com
version.name: tizi.01
C:\Windows\System32\drivers\etc\hosts 模拟zuul网关
127.0.0.1 www.lijie.com
启动Eureka7001 或者7002 7003都行,启动一个提供者8001 启动9527
www.lijie.com:9527/springcloud-provider-dept/dept/get/3 访问
我们可以看到能查询到数据,但是项目路径中已暴露出真实的微服务地址,还需要进行修改配置。
在application.yml 配置Zuul网关
zuul:
routes:
mydept.serviceId: springcloud-provider-dept
#之前的查询链接地址 http://www.lijie.com:9527/springcloud-provider-dept/dept/get/1
#现在的查询链接地址,配置后为 http://www.lijie.com:9527/mydept/dept/get/1
#两者都皆可访问(原路径+现配路径)。配置自定义的前缀后 可不让客户端知道真实的ip地址
mydept.path: /mydept/**
再次运行项目。可看到只能通过我们指定的配置中的path路径访问
我们还可以添加配置,全部的配置
zuul:
routes:
mydept.serviceId: springcloud-provider-dept
#之前的查询链接地址 http://www.lijie.com:9527/springcloud-provider-dept/dept/get/1
#现在的查询链接地址,配置后为 http://www.lijie.com:9527/mydept/dept/get/1
#两者都皆可访问(原路径+现配路径)。配置自定义的前缀后 可不让客户端知道真实的ip地址
mydept.path: /mydept/**
#加上此配置后 原路径不能访问(springcloud-provider-dept/dept/get/6),只能通过自定义的规则路径访问。
#ignored-services: springcloud-provider-dept
#星号(*) 隐藏全部的项目真实名字
ignored-services: "*"
prefix: /li #设置公共的地址前缀 配置后链接为:www.lijie.com:9527/li/mydept/dept/get/11
再次启动zuul启动类,可看到是我们自定义的路由规则,可有效的隐藏真实服务名及地址。
访问:www.lijie.com:9527/li/mydept/dept/get/11