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/

如图:

生产者微服务配置

    网关服务配置(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

如图:

网关服务配置

    网关服务配置(Application.java)

        @SpringBootApplication

        @EnableZuulProxy    // 启用Zuul代理

    如图:

主类配置

二.服务启动

网关服务启动

    加载zuul routes配置:

zuul配置类

    加载后属性为LinkedHashMap结构,处理缺省属性,ZuulRoute为ZuulProperties内部类

routes缺省参数初始化

    Zuul代理类加载:

代理类自动装配

    初始化路由转发过滤器RibbonRoutingFilter:

装载Bean

      构造RibbonRoutingFilter:

执行RibbonRoutingFilter  构造器

    显示配置已加载:

ZuulProperties.routes装载结果

三.示例:

        访问地址:localhost:5555/api-a/index

        进入过滤顺序为10的RibbonRoutingFilter:

顺序=10

        判断是否执行过滤器(依赖com.netflix.zuul.context.RequestContext):

执行判断及CTX属性

        执行过滤器,先构造RibbonCommandContext上下文:

开始执行过滤器

        构造请求头,请求参数,负载等:

构造负载上下文

        RibbonCommand执行转发:

执行转发并返回响应结果

        吧啦吧啦到达服务返回结果,catch异常。。。先到这

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。