SpringCloud Zuul路由转发原理及源码解析
一.配置文件
生产者服务配置:
server.port=8081
spring.application.name=first-service
eureka.instance.instance-id=${spring.application.name}:${random.int}
eureka.client.serviceUrl.defaultZone=http://localhost:1111/eureka/
如图:
![](https://img.haomeiwen.com/i10081150/333cbb8c07bd3aa1.png)
网关服务配置(application.properties):
server.port=5555
spring.application.name=api-gateway
eureka.instance.instance-id=${spring.application.name}:${random.int}
eureka.client.serviceUrl.defaultZone=http://localhost:1111/eureka/
# 表示eureka client发送心跳给server端的频率。如果在leaseExpirationDurationInSeconds后,server端没有收到client的心跳,则将摘除该instance。缺省=30
eureka.instance.lease-renewal-interval-in-seconds=30
# 表示eureka server至上一次收到client的心跳之后,等待下一次心跳的超时时间,在这个leaseExpirationDurationInSeconds时间内若没收到下一次心跳,则将移除该instance,缺省=90
eureka.instance.lease-expiration-duration-in-seconds=90
zuul.routes.api-a-url.path=/api-a/**
zuul.routes.api-a-url.service-id=first-service
zuul.routes.api-b-url.path=/api-b/**
zuul.routes.api-b-url.service-id=feign-consumer
如图:
![](https://img.haomeiwen.com/i10081150/bc0beee5ad4aa83e.png)
网关服务配置(Application.java)
@SpringBootApplication
@EnableZuulProxy // 启用Zuul代理
如图:
![](https://img.haomeiwen.com/i10081150/53b171e5395e7654.png)
二.服务启动
网关服务启动
加载zuul routes配置:
![](https://img.haomeiwen.com/i10081150/17dfd3afea3428ab.png)
加载后属性为LinkedHashMap结构,处理缺省属性,ZuulRoute为ZuulProperties内部类
![](https://img.haomeiwen.com/i10081150/7d001033fad6ce6f.png)
Zuul代理类加载:
![](https://img.haomeiwen.com/i10081150/deb07d459ca56361.png)
初始化路由转发过滤器RibbonRoutingFilter:
![](https://img.haomeiwen.com/i10081150/dc1d98b6f2c13ab7.png)
构造RibbonRoutingFilter:
![](https://img.haomeiwen.com/i10081150/3ca6c81b6572b38a.png)
显示配置已加载:
![](https://img.haomeiwen.com/i10081150/7e4e5aad385c0270.png)
三.示例:
访问地址:localhost:5555/api-a/index
进入过滤顺序为10的RibbonRoutingFilter:
![](https://img.haomeiwen.com/i10081150/217d4e59b3f24789.png)
判断是否执行过滤器(依赖com.netflix.zuul.context.RequestContext):
![](https://img.haomeiwen.com/i10081150/26305d0c252ac901.png)
执行过滤器,先构造RibbonCommandContext上下文:
![](https://img.haomeiwen.com/i10081150/bab4e1e1fa26d752.png)
构造请求头,请求参数,负载等:
![](https://img.haomeiwen.com/i10081150/5c5605b6a4e3ad51.png)
RibbonCommand执行转发:
![](https://img.haomeiwen.com/i10081150/ad5ada0cd0ca7352.png)
吧啦吧啦到达服务返回结果,catch异常。。。先到这