加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 运营中心 > Nginx > 正文

Nginx动态上游配置/路由

发布时间:2020-12-13 21:17:38 所属栏目: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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读