zuul+websocket+sockjs

JavaScript024

zuul+websocket+sockjs,第1张

需要实现前端页面->zuul网关->消息服务,建立websocket连接

使用 spring-cloud-netflix-zuul-websocket 实现zuul网关层对websocket的转发;

注意事项:

1.前端使用sockjs,注意地址前缀

2.后端注意开启跨域和指定sockjs协议:

3.zuul层配置:

注意:

参考:

原文地址:

https://blog.csdn.net/u011429231/article/details/82498795

之前的项目中,使用zuul网关统一过滤域名,为了管理方便,想要尝试看看能不能使用zuul管理websocket连接。

高版本的websocket在第一次http请求后,使用的是更快速的tcp连接

zuul网关只能管理http请求,并且不支持tcp以及udp请求

zuul转发websocket时,会将websocket降级为http请求转发掉(轮询的方式),换句话说就是不支持转发长连接,zuul2好像可以,详细情况看下面提供的链接

最好是不要通过zuul来管理websocket连接,降级为轮询后,效率会降低很多。

因为打算把服务器的websocket功能转接到我的这个zuul代理服务器来做,所以就不再研究怎么转发websocket了。

因为考虑到一个问题,那就是灰度发布的时候,需要将全部请求转发到灰度版的服务器作为现在的主服务器,那么原服务器的那些websocket长连接怎么办?肯定断了啊,那怎么继续在现在的服务器上保持?就是因为这一点所以才把websocket功能放到代理服务器实现的。

也不知道其他公司都是怎么做的,怎么解决我说的问题,望告知!感谢!

我现在把websocket功能放到代理服务器来做,万一以后业务要增加websocket功能,那岂不是得停服更新代理服务器,可是目的就是不停服啊

        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/

如图:

        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

如图:

        @SpringBootApplication

        @EnableZuulProxy    // 启用Zuul代理

    如图:

    加载zuul routes配置:

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

    Zuul代理类加载:

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

      构造RibbonRoutingFilter:

    显示配置已加载:

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

        进入过滤顺序为10的RibbonRoutingFilter:

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

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

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

        RibbonCommand执行转发:

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