我正在尝试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实现动态上游
原文链接:https://www.f2er.com/nginx/435406.htmlhttp://sosedoff.com/2012/06/11/dynamic-nginx-upstreams-with-lua-and-redis.html