美文网首页
上传大文件时绕过zuul的两种方法

上传大文件时绕过zuul的两种方法

作者: eagle_424 | 来源:发表于2019-12-06 23:28 被阅读0次

默认情况下,所有的请求经过Zuul网代理,默认会通过SpringMVC预先对请求进行处理,缓存。普通请求并不会有什么问题,但是对于文件上传,就会造成不必要的网络负担。在高并发时,可能导致网络瘫痪,网络阻塞,Zuul网关不可用。这样我们的整个系统就瘫痪了。

所以,我们上传文件的请求需要绕过Zuul的请求缓存,直接通过路由到达目标微服务。

官方提供了一种解决办法就是在请求路径前加上/zuul,比如在请求为/api/upload,改为/zuul/api/upload就可以绕过zuul缓存。在微服务的架构中,我们可以通过nginx的rewrite指令实现对url重写。

location /api/upload {

    proxy_pass http://127.0.0.1:zuul端口;

    proxy_connect_timeout 600;

    proxy_read_timeout 600;

    rewrite "/(.*)$" /zuul/$1;

}

重写后路径映射就变为//127.0.0.1:zuul端口/zuul/api/upload,请求转发到zuul网关时就不会再进行请求预处理而直接找到相应服务。

第二种方法也就顾名思义,既然要绕过zuul那么nginx在映射路径时就不在映射到zuul而直接映射到微服务。

location /api/upload {

    proxy_pass http://127.0.0.1:微服务端口;

    proxy_connect_timeout 600;

    proxy_read_timeout 600;

    rewrite "^/api/(.*)$" /$1 break;

}

这样网关也不需要去拉取上传文件的微服务,可以配置直接忽略。

zuul: 

     ignored-services: 

        - upload-service # 忽略upload-service服务

两种方法的不同之处是第一种方式还是会经过zuul,只不过不再进行缓存,而第二种方法是真正绕过了zuul。

为了保证高可用性和负载均衡,将来我们zuul,和微服务肯定不会只有一个,都是以集群的方式搭建,所以第一种方式对微服务的负载均衡由zuul来实现,而第二种方法则是通过nginx实现。

相关文章

网友评论

      本文标题:上传大文件时绕过zuul的两种方法

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