美文网首页
SpringCloud Zuul路由转发原理及源码解析

SpringCloud Zuul路由转发原理及源码解析

作者: 疯狂的二狗 | 来源:发表于2019-08-24 18:14 被阅读0次

    一.配置文件

        生产者服务配置:    

            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异常。。。先到这

    相关文章

      网友评论

          本文标题:SpringCloud Zuul路由转发原理及源码解析

          本文链接:https://www.haomeiwen.com/subject/cpvqoxtx.html