SpringCloud-Zuul(一):技术选型及请求流程源码走读

栏目: Java · 发布时间: 5年前

内容简介:最近公司最新架构确定使用微服务之后,经过讨论,最终还是选用了springcloud选用了最新的稳定版本使用Zuul的关键在于自定义

最近公司最新架构确定使用微服务之后,经过讨论,最终还是选用了 SpringCloud 的体系。我负责网关,鉴权服务的研发。记录下这段时间新接触的知识。

网关技术选型

springcloud选用了最新的稳定版本 Greenwich ,所以对于网关来说,有两种框架选择: SpringCloud GatewayZuul ,经过调研我最终选用了Zuul,原因如下:

  1. 目前项目在一个快速迭代的过程中,Zuul相比于Gateway来说更加稳定。
  2. Gateway文档还有待完善,我在调查过程中,发现官网文档甚至代码还留有很多 TODO ,这不是一个大坑吗!Gateway文档
  3. Gateway相对Zuul来说显得难以使用,Gateway使用Spring5开发,基于函数,响应式编程,可能对于刚接触 Reactive 的人来说阅读源码有一定难度。
  4. 虽然Zuul在性能上来说不如Gateway,但对于我们的业务来说这点时间消耗显得不那么重要。
Proxy	    Avg Latency	    Avg Req/Sec/Thread
gateway	    6.61ms	        3.24k
linkered	7.62ms	        2.82k
zuul	    12.56ms	        2.09k
none	    2.09ms	        11.77k
复制代码

Zuul工作原理

使用Zuul的关键在于自定义 Filter ,当然这个Filter不是Servlet对应的Filter,并且不同类型的Filter使用相同的配置却有不同的效果。秉着 知其所以然 的精神,把整个Zuul处理过程的源码debug了一遍;

入口

Zuul处理请求的入口是一个Servlet: ZuulServlet ,SpringCloud也提供另外的处理入口,一个Servlet Filter: ZuulServletFilter ,修改配置文件 zuul.use-filter=true 即可。 它进入ZuulServlet的过程如下:

SpringCloud-Zuul(一):技术选型及请求流程源码走读

http依然先进入DispatchServlet,接着调用ZuulController,再接着调用ZuulServlet。这中间经过不少反射处理,可能这也是性能低的一个原因。不太明白为什么不直接进入ZuulServlet。

源码走读

SpringCloud-Zuul(一):技术选型及请求流程源码走读

进入了ZuulServlet后,调用service方法,这个时候就开始调用各个类型的ZuulFilter了,它主要做了如下事情。

  1. 初始化RequestContext,其实就是一个 ThreadLocal ,将httpServlet,httResponse放入其中,方便后面自定义的ZuulFilter可以获取。
  2. 调用 pre filter
  3. 调用 route filter
  4. 调用 post filter 注意点:再调用各个filter的过程中如果出现异常,都会调用 error filter 接着我们查看pre filter是如何调用的:
    SpringCloud-Zuul(一):技术选型及请求流程源码走读
    SpringCloud-Zuul(一):技术选型及请求流程源码走读
    SpringCloud-Zuul(一):技术选型及请求流程源码走读
    SpringCloud-Zuul(一):技术选型及请求流程源码走读
    也就是说,现在上面的流程图变成了这样:
    SpringCloud-Zuul(一):技术选型及请求流程源码走读
    这样,我们的思路就很清晰了,从请求进入,到zuul的调用完整过程都已经整理了出来,接下来我们只要开始自定义filter处理我们的业务逻辑即可。

总结

本章我们从技术选型出发,比较了zuul和gateway的优缺点。最后通过阅读源码的方式整理了Zuul处理请求的整个过程。 下一章: 如何自定义Zuul Filter以及所遇到坑!

关注我,这里只有干货!


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

创业之初你不可不知的融资知识

创业之初你不可不知的融资知识

桂曙光 / 机械工业出版社 / 2010-6-1 / 48.00元

从零到精通 成功融资必读书 像小说一样好看的趣味融资书 手把手教你找到VC拿到钱 本书以创业者寻找风险投资的逻辑顺序为主线,运用理论分析和实例剖析相结合的手法,将简洁、通俗的语言与丰富的图表工具相结合,辅以中肯的建议,同时运用大量鲜活的、有代表性的成败案例,为读者解读创业之初企业有效成功融资的途径和方法,帮助你的企业开创新的辉煌。一起来看看 《创业之初你不可不知的融资知识》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具