Nginx动态上游配置/路由

我正在尝试nginx的动态上游配置,并且无法找到任何好的解决方案来实现第三方源(如redis或mysql)的上游配置.其背后的想法是在主服务器中具有单个文件配置,并且基于环境条件对各个应用服务器进行代理请求.考虑动态部署,其中有X服务器在不同端口上运行Y worker.例

我正在尝试nginx的动态上游配置,并且无法找到任何好的解决方案来实现第三方源(如redis或mysql)的上游配置.

其背后的想法是在主服务器中具有单个文件配置,并且基于环境条件对各个应用服务器进行代理请求.考虑动态部署,其中有X服务器在不同端口上运行Y worker.例如,我创建一个新的应用程序并进行部署.应用程序管理器选择一个服务器,然后推出一个工作程序(Ruby / PHP / Python),然后将ip:port报告给状态为“up”的中央数据库.此时,当我转到给定的url时,nginx应该将所有请求代理到指定的ip:port upstream.整个过程非常类似于heroku所做的事情,除了这个概念验证不应该是生产就绪,主要是为了满足内部需求.

我找到的最简单的解决方案是使用带有基于ruby的DNS服务器的解析器.它工作正常,nginx正确获取IP地址,但唯一的问题是你无法定义该IP的端口号.

第二个解决方案(我还没试过)是将其他东西作为代理服务器滚动,也许用Erlang编写.在这种情况下,我们需要使用一些东西来提供静态内容.

有任何想法如何以更灵活和稳定的方式实现这一点?

附:一些研究选择:

> http://openresty.org/#DynamicRoutingBasedOnRedis
> https://github.com/nodejitsu/node-http-proxy
最佳答案
这与Michael Hampton引用的完全相同 – 使用Lua实现动态上游

http://sosedoff.com/2012/06/11/dynamic-nginx-upstreams-with-lua-and-redis.html

作者: dawei

【声明】:永州站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

为您推荐

联系我们

联系我们

0577-28828765

在线咨询: QQ交谈

邮箱: xwei067@foxmail.com

工作时间:周一至周五,9:00-17:30,节假日休息

返回顶部