网关处理流程
请求进入->pre(鉴权/限流)->route(路由到其他服务) ->post(处理响应)
本质就是Filter
ZuulServlet->preRoute()、postRoute()、error()
主要Filter流程
PreDecorationFilter:解析决定使用哪种url。(通过获取eureka中的服务名【正确来说是虚拟主机名】),解析url地址,获取到当前要使用的是哪个 route。
RibbonRoutingFilter:向微服务发请求(实际替换ip,port)
SendResponseFilter:接受微服务响应,并向用户响应。
过滤器执行流程
可以看ZuulServlet
pre异常: pre -> error -> post
route异常: pre -> route -> error -> post
post异常: pre -> route -> post -> error
正常: pre -> route -> post
为什么最后都要走post,因为post最后,才能直接给用户响应数据。
pre:表示路由的前置过滤器链,route:表示路由的过滤器链,post:表示路由的后置过滤器链,error:表示路由错误过滤器链。
由此可见,责任链模式是zuul的核心。
过滤器排序
根据order排序,底层通过根据filterOrder排序
Collections.sort(list); // sort by priority
过滤器顺序
FilterConstants
看里面的顺序,可以定义自己的过滤器 何时执行。
网关源码总流程
流程总结:zuulServlet->ZuulerRunner->FilterProcessor
主要执行在FilterProcessor(获取过滤器列表,然后执行),