SpringCloud08-Zuul路由网关

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值