动态流量管理方案Upsync.zip

时间:2022-08-06 01:22:09
【文件属性】:

文件名称:动态流量管理方案Upsync.zip

文件大小:405KB

文件格式:ZIP

更新时间:2022-08-06 01:22:09

开源项目

Upsync,微博开源基于Nginx容器动态流量管理方案 。Nginx 以其超高的性能与稳定性,在业界获得了广泛的使用,微博的七层就大量使用了 Nginx 。结合 Nginx 的健康检查模块,以及动态 reload 机制,可以近乎无损的服务的升级上线与扩容。这个时候扩容的频次比较低,大多数情况下是有计划的扩容。Upsync,开发了模块 nginx-upsync-module,它的功能是拉取 consul 的后端 server 的列表,并更新 Nginx 的路由信息。此模块不依赖于任何第三方模块。consul 作为 Nginx 的 db,利用 consul 的 KV 服务,每个 Nginx work 进程独立的去拉取各个 upstream 的配置,并更新各自的路由。流程图如下:应用案例:模块已经应用在微博的各类业务中,下面图表对比分析使用模块前后的 QPS 与耗时变化。从数据可以得出,reload 操作时造成 nginx 的请求处理能力下降约 10%,Nginx 本身的耗时会增长 50% 。若是频繁的扩容缩容,reload 操作造成的开销会更加明显。官方商业版对 Nginx plus 支持了 DNS 与 push 版本提供了支持。在使用过程中因为数据一致性等问题,扩展支持了基于 consul 的 pull 版本。 标签:Upsync


【文件预览】:
nginx-upsync-module-master
----config(664B)
----test()
--------consul.sh(80B)
--------test.sh(89B)
--------t()
--------README(10KB)
----src()
--------ngx_http_upsync_module.c(119KB)
--------ngx_http_parser.h(12KB)
--------ngx_http_upsync_module.h(11KB)
--------ngx_http_json.c(21KB)
--------ngx_http_parser.c(68KB)
--------ngx_http_json.h(7KB)
----doc()
--------images()
--------FAQ.md(0B)
--------README.md(12KB)
----README.md(14KB)
----.gitattributes(56B)

网友评论