1、zuul简介

1.1、zuul是什么

zuul 是netflix开源的一个API Gateway 服务器, 本质上是一个web servlet应用。

Zuul 在云平台上提供动态路由,监控,弹性,安全等边缘服务的框架。Zuul 相当于是设备和 Netflix 流应用的 Web 网站后端所有请求的前门。

Zuul的主要功能是路由转发和过滤器。路由功能是微服务的一部分,比如/api/user转发到到user服务,/api/shop转发到到shop服务。zuul默认和Ribbon结合实现了负载均衡的功能。

1.2、zuul能做什么

zuul的核心是一系列的filters, 其作用可以类比Servlet框架的Filter,或者AOP。

Zuul可以通过加载动态过滤机制,从而实现以下各项功能:

验证与安全保障: 识别面向各类资源的验证要求并拒绝那些与要求不符的请求。

审查与监控: 在边缘位置追踪有意义数据及统计结果,从而为我们带来准确的生产状态结论。

动态路由: 以动态方式根据需要将请求路由至不同后端集群处。

压力测试: 逐渐增加指向集群的负载流量,从而计算性能水平。

负载分配: 为每一种负载类型分配对应容量,并弃用超出限定值的请求。

静态响应处理: 在边缘位置直接建立部分响应,从而避免其流入内部集群。

多区域弹性: 跨越AWS区域进行请求路由,旨在实现ELB使用多样化并保证边缘位置与使用者尽可能接近。

2、创建service-zuul工程

2.1、创建service-zuul工程,pom.xml文件如下

4.0.0

com.lishun

service-zuul

0.0.1-SNAPSHOT

jar

service-zuul

Demo project for Spring Boot

com.lishun

cloud

1.0-SNAPSHOT

org.springframework.cloud

spring-cloud-starter-netflix-zuul

org.springframework.cloud

spring-cloud-starter-netflix-eureka-client

org.springframework.boot

spring-boot-starter-web

2.2、在其入口applicaton类加上注解@EnableZuulProxy,开启zuul的功能:

@EnableZuulProxy

@EnableEurekaClient

@SpringBootApplicationpublic classServiceZuulApplication {public static voidmain(String[] args) {

SpringApplication.run(ServiceZuulApplication.class, args);

}

}

2.3、加上配置文件application.yml加上以下的配置代码:

eureka:

client:

serviceUrl:

defaultZone: http://localhost:8761/eureka/

server:

port: 8769

spring:

application:

name: service-zuul

zuul:

routes:

api-a:

path: /api-a/**

serviceId: service-ribbon

api-b:

path: /api-b/**

serviceId: service-feign

首先指定服务注册中心的地址为http://localhost:8761/eureka/,服务的端口为8769,服务名为service-zuul;

以/api-a/ 开头的请求都转发给service-ribbon服务;以/api-b/开头的请求都转发给service-feign服务;

2.4、启动5个服务,浏览器访问 http://localhost:8769/api-a/hi?name=lis 页面显示

hi lis ,i am from port:8762

浏览器访问 http://localhost:8769/api-b/hi?name=lis 页面显示

hi lis ,i am from port:8762

这说明zuul起到了路由的作用

3、服务过滤

前面提到,Zuul通过加载动态过滤机制,不仅可以实现路由功能,还能实现验证,检查,监控等功能。

下面使用zuul来实现安全验证功能

@Componentpublic class MyFilter extendsZuulFilter {private static Logger log = LoggerFactory.getLogger(MyFilter.class);

@OverridepublicString filterType() {return "pre";

}

@Overridepublic intfilterOrder() {return 0;

}

@Overridepublic booleanshouldFilter() {return true;

}

@Overridepublic Object run() throwsZuulException {

RequestContext ctx=RequestContext.getCurrentContext();

HttpServletRequest request=ctx.getRequest();

log.info(String.format("%s >>> %s", request.getMethod(), request.getRequestURL().toString()));

Object accessToken= request.getParameter("token");if(accessToken == null) {

log.warn("token is empty");

ctx.setSendZuulResponse(false);

ctx.setResponseStatusCode(401);try{

ctx.getResponse().getWriter().write("token is empty");

}catch(Exception e){}return null;

}

log.info("ok");return null;

}

}

filterType:返回一个字符串代表过滤器的类型,在zuul中定义了四种不同生命周期的过滤器类型,具体如下:

pre:路由之前

routing:路由之时

post: 路由之后

error:发送错误调用

filterOrder:过滤的顺序

shouldFilter:这里可以写逻辑判断,是否要过滤,本文true,永远过滤。

run:过滤器的具体逻辑。可用很复杂,包括查sql,nosql去判断该请求到底有没有权限访问。

token is empty

hi lis ,i am from port:8762

zuul两大作用_springCloud学习- 路由网关(zuul)相关推荐

  1. zuul两大作用_SpringCloud微服务(05):Zuul组件,实现路由网关控制

    一.Zuul组件简介 1.基础概念 Zuul 网关主要提供动态路由,监控,弹性,安全管控等功能.在分布式的微服务系统中,系统被拆为了多个微服务模块,通过zuul网关对用户的请求进行路由,转发到具体的后 ...

  2. 史上最简单的SpringCloud教程 | 第五篇: 路由网关(zuul)

    转:https://blog.csdn.net/forezp/article/details/69939114 最新版本: 史上最简单的SpringCloud教程 | 第五篇: 路由网关(zuul)( ...

  3. 第九章:路由网关(Zuul)的使用

    2019独角兽企业重金招聘Python工程师标准>>> 第九章:路由网关(Zuul)的使用 前言 介绍完分布式配置中心,结合前面的文章.我们已经有了一个微服务的框架了,可以对外提供a ...

  4. 闭包的两大作用:保存/保护

    闭包的概念 函数执行时形成的私有上下文EC(FN),正常情况下,代码执行完会出栈后释放;但是特殊情况下,如果当前私有上下文中的某个东西被上下文以外的事物占用了,则上下文不会出栈释  放, 从而形成不销 ...

  5. SpringCloud教程- 路由网关Zuul (SpringCloud版本Greenwich.SR4)

    文章目录 Zuul简介 创建zuul-gateway工程 服务过滤 代码地址:github-spring-cloud地址 Zuul简介 Zuul是NetFlix开源的微服务网关,它可以和Eureka. ...

  6. 第五篇:路由网关(zuul) zuul路由 服务过滤 (Finchley版本)V2.0_dev

    前言: 在微服务架构中,需要几个基础的服务治理组件,包括服务注册与发现.服务消费.负载均衡.断路器.智能路由.配置管理等,由这几个基础组件相互协作,共同组建了一个简单的微服务系统. 在Spring C ...

  7. springcloud 之 路由网关 zuul

    话不多说,先上图(图是丑陋了点,大家别介意哈),这幅图是我根据公司现有的业务设计出来的一个简单的基于springcloud微服务架构图. 在springcloud微服务体系中,我们一般不对外直接暴露服 ...

  8. SpringCloud 学习--路由网关

    在微服务架构中,需要几个基础的微服务,包括服务的注册与发现,服务消费,负载均衡,断路器,咋能路由,配置管理等,由这几几个基础组件相互协作,共用组建一个简单的微服务系统. -Zuul 简介 Zuul是N ...

  9. java B2B2C Springboot电子商城系统-路由网关(zuul)

    一.Zuul简介 Zuul的主要功能是路由转发和过滤器.路由功能是微服务的一部分,比如/api/user转发到到user服务,/api/shop转发到到shop服务.zuul默认和Ribbon结合实现 ...

最新文章

  1. AngularJS中选择样式
  2. 第一篇读书笔记,关于UML和模式应用(1)--书籍简介
  3. MATLAB观察系统响应,基于MATLAB的系统的时域响应分析精选.doc
  4. Doc命令收集(一)
  5. [luogu3676]小清新数据结构题
  6. kali安装python3.7_Debian服务器之安装Python3.7
  7. 消解原理推理_什么是推理统计中的Z检验及其工作原理?
  8. linux中常用的shell脚本,Linux常用shell脚本
  9. LeetCode——Word Break
  10. poj 3040 Allowance (贪心
  11. 解决springboot jar包冲突
  12. 了解单片机解密的一些知识
  13. EnableViewState属性
  14. 数据挖掘中的关联规则
  15. L1-020. 帅到没朋友
  16. 如何选择SCI期刊并能顺利发表
  17. 2022-2028年全球及中国汽车保险丝行业投资前景分析
  18. 赛尔号找不到服务器ip,赛尔号互通版
  19. github新手使用指南
  20. 测试、前端、产品经理的一般要求

热门文章

  1. JSD-2204-创建Spring项目-Day19
  2. 360浏览器和搜狗浏览器查看双内核版本及如何控制内核版本
  3. php 跳转邮箱,JS点击跳转登陆邮箱功能简单的实现方法
  4. 舆情监测技术TOOM,web技术实现
  5. python中的相对导入//__name__和__package__的作用//以及相对导入的两个经典错误
  6. 关于浏览器方向的大厂面试题
  7. 【圈外同学】Day01 一个模型,帮你找到真正热爱的
  8. Docker指定网桥和指定网桥IP
  9. 使用Python将Word表格嵌入Excel中!
  10. OA协同办公系统功能介绍