微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Nginx动态上游配置/路由

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

其背后的想法是在主服务器中具有单个文件配置,并且基于环境条件对各个应用服务器进行代理请求.考虑动态部署,其中有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

原文地址:https://www.jb51.cc/nginx/435406.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐