【问题标题】:Load balancing strategies on nginxnginx上的负载均衡策略
【发布时间】:2015-05-18 10:39:43
【问题描述】:

为了解决不断扩大的服务器负载,我想出了一个解决方案,为我的网站的访问者呈现纯 HTML 网站。因此,访问者被路由到纯 html 站点,而注册用户被路由到动态站点。 为了分隔两个不同的用户组,我使用了 cookie。我使用的负载均衡器和 Web 服务器是 nginx。

nginx 配置文件如下所示:

set $cookie_set 0;
if ($http_cookie ~ 'mysite.com') {
        set $cookie_set 1;
}
location / {
        if ($cookie_set ~ 0) {
               proxy_pass http://static-site;
        }
        if ($cookie_set ~ 1) {
                proxy_pass http://dynamic-site;
        }
}

上述策略有效,但并非万无一失。在某些情况下这不起作用,例如使用不支持 cookie 和错误创建的 cookie 的浏览器。

必须有更复杂的策略来做到这一点。欢迎任何经验、cmets 和想法。

【问题讨论】:

    标签: cookies nginx load-balancing web-storage


    【解决方案1】:

    这是需要真正的负载平衡器的地方,例如 HAProxy。 使用 HAProxy,您可以根据当前后端服务器场容量路由流量。

    当动态的开始排队时,下面的配置片段将流量转发到静态后端。

    frontend
    
     use_backend bk_static if { queue(bk_dynamic) ge 1 }
     default_backend bk_dynamic
    
    backend bk_static
    
    backend bk_dynamic
    

    相同类型的配置可以应用于 bk_dynamic 后端上的许多正在运行的会话。

    巴蒂斯特

    【讨论】:

    • 酷。唯一不需要的问题是,如果动态站点开始排队,注册用户将看到访问者内容。我正在寻找一种持久的解决方案来分离不依赖于服务器负载的访问者和注册用户。
    猜你喜欢
    • 2019-04-10
    • 2013-04-28
    • 1970-01-01
    • 1970-01-01
    • 2017-01-17
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多