水平扩展:在服务器之间路由用户生成的子域


Horizontal scaling: routing user-generated subdomains between servers

我维护一个超过单个VPS的Web应用程序。该体系结构由大量小用户组成,每个用户都有自己的子域。用户不交互。加载意味着我必须将一些用户和所有新用户移动到单独服务器上的另一个 Web 应用程序安装。

目前,每个用户子域都属于同一个虚拟主机,其中单个 PHP 前端控制器根据主机名显示适当的内容。*.mydomain.com 的单个通配符 DNS 记录指向当前服务器。

将不同的用户子域路由到不同服务器的最佳选择是什么?

我的想法:

  • 每个服务器的新顶级域。 user.s1.mydomain.com、user.s2.mydomain.com 等(不优雅和泄露信息)
  • 运行我自己的DNS服务器以在服务器之间路由用户(额外的故障点,不熟悉的技术)
  • 中央前端控制器/平衡器,可将每个请求反向代理到适当的服务器(额外的故障点,可能有限的连接)

在应用程序横向扩展的那一点,我会使用中央前端负载均衡器。Nginx应该处理由单个服务器动态提供的任何负载。我们有nginx作为六个动态服务器和一个静态内容服务器的前端,nginx上看不到瓶颈。

在您的缩放点上,设置 nginx 以处理所有静态内容本身,并根据需要将动态内容反向代理到任意数量的框中。简单代理传递的设置接近:

upstream upstream_regular_backend {
    fair;
    server 10.0.0.1:80;
    server 10.0.0.2:80;
}
server {
    listen 0.0.0.0:80;
    server_name  example.com;
    proxy_set_header Host $host;
    proxy_set_header  X-Real-IP  $remote_addr;
    location / {
        proxy_pass http://upstream_regular_backend;
    }
}

为了提供静态内容并传回所有其余内容,如下所示:

server {
    listen 0.0.0.0:80;
    server_name  example.com;
    proxy_set_header Host $host;
    proxy_set_header  X-Real-IP  $remote_addr;
    index index.php;
    root /some/dir/:
    location ~ '.php {
        proxy_pass http://upstream_regular_backend;
    }
}

当然,如果您不使用 PHP,请相应地调整配置。

在上游定义中,"fair;"将根据响应时间对后端进行负载均衡。出于缓存动机,您可能希望改用"ip_hash;",因为它将始终在同一服务器上登陆来自客户端的请求。

我们的设置有点远。我们有nginx负载均衡器代理清漆缓存,而清漆缓存又代理动态内容服务器。

如果您担心nginx是单点故障,请设置一个辅助服务器,以便在发生故障时承担前端的IP。