10

我知道多个 node.js,我假设通过扩展 Meteor,可以使用 Nginx 在一台服务器上运行。我已经安装好 Nginx 并在 Ubuntu 服务器上运行得很好,我什至可以让它响应请求并将它们代理到我的一个应用程序。然而,当我试图让 Nginx 将流量代理到第二个应用程序时,我遇到了障碍。

一些背景:

  • 在端口 8001 上运行的第一个应用程序
  • 在端口 8002 上运行的第二个应用程序
  • Nginx 监听 80 端口
  • 试图让 nginx 在 / 向应用程序一发送流量,在 /app2/ 向应用程序二发送流量
  • 这两个应用程序都可以通过转到 domain:8001 和 domain:8002 来访问

我的 Nginx 配置:

upstream mydomain.com {
server 127.0.0.1:8001;
server 127.0.0.1:8002;
}

# the nginx server instance
server {
listen 0.0.0.0:80 default_server;
access_log /var/log/nginx/mydomain.log;

location /app2 {
  rewrite /app2/(.*) /$1 break;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  proxy_set_header Host $http_host;
  proxy_set_header X-NginX-Proxy true;
  proxy_pass http://127.0.0.1:8002;
  proxy_redirect off;
  proxy_http_version 1.1;
  proxy_set_header Upgrade $http_upgrade;
  proxy_set_header Connection "upgrade";
}

location / {
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  proxy_set_header Host $http_host;
  proxy_set_header X-NginX-Proxy true;
  proxy_pass http://127.0.0.1:8001;
  proxy_redirect off;
  proxy_http_version 1.1;
  proxy_set_header Upgrade $http_upgrade;
  proxy_set_header Connection "upgrade";
}
}

任何有关当流量转到 /app2/ 时可能发生的情况的见解,我将不胜感激!

4

2 回答 2

27
proxy_pass http://127.0.0.1:8002/1;  <-- these should be 
proxy_pass http://**my_upstream_name**;  <--these

然后

upstream my_upstream_name {  

//Ngixn do a round robin load balance, some users will conect to / and othes to /app2

server 127.0.0.1:8001;

server 127.0.0.1:8002;

}

一些技巧控制代理:

看看这里 @nginx 文档

然后我们开始:

weight = NUM​​BER - 设置服务器的权重,如果没有设置权重等于一。不平衡默认循环。

max_fails = NUM​​BER - 在一段时间内(由参数 fail_timeout 分配)内尝试与服务器通信失败的次数,之后它被视为不工作。如果未设置,则尝试次数为 1。值 0 将关闭此检查。什么被认为是失败由 proxy_next_upstream 或 fastcgi_next_upstream 定义(除了不计入 max_fails 的 http_404 错误)。

fail_timeout = TIME - 必须发生的时间 *max_fails* 与服务器通信失败的尝试次数,这将导致服务器被视为不工作,以及服务器将被视为不工作的时间(在再次尝试之前)。如果未设置时间为 10 秒。fail_timeout 与上游响应时间无关,使用 proxy_connect_timeout 和 proxy_read_timeout 来控制。

down - 将服务器标记为永久离线,与指令 ip_hash 一起使用。

备份- (0.6.7 或更高版本)仅在非备份服务器全部关闭或忙碌时使用此服务器(不能与指令 ip_hash 一起使用)

EXAMPLE generic

    upstream  my_upstream_name  {
      server   backend1.example.com    weight=5;
      server   127.0.0.1:8080          max_fails=3  fail_timeout=30s;
      server   unix:/tmp/backend3;
    }
//   proxy_pass http://my_upstream_name; 

这些是你需要的:

如果您只想控制一个应用程序的虚拟主机之间的卸载:

 upstream  my_upstream_name{
          server   127.0.0.1:8080          max_fails=3  fail_timeout=30s;
          server   127.0.0.1:8081          max_fails=3  fail_timeout=30s;
          server   127.0.0.1:8082          max_fails=3  fail_timeout=30s;
          server   127.0.0.1:8083 backup;
//  proxy_pass http://my_upstream_name; 
// amazingness no.1, the keyword "backup" means that this server should only be used when the rest are non-responsive
    } 

如果您有 2 个或更多应用程序:每个应用程序 1 个上游,例如:

upstream  my_upstream_name{
              server   127.0.0.1:8080          max_fails=3  fail_timeout=30s;
              server   127.0.0.1:8081          max_fails=3  fail_timeout=30s;
              server   127.0.0.1:8082          max_fails=3  fail_timeout=30s;
              server   127.0.0.1:8083 backup;  
            } 
upstream  my_upstream_name_app2  {
              server   127.0.0.1:8084          max_fails=3  fail_timeout=30s;
              server   127.0.0.1:8085          max_fails=3  fail_timeout=30s;
              server   127.0.0.1:8086          max_fails=3  fail_timeout=30s;
              server   127.0.0.1:8087 backup; 
            } 
upstream  my_upstream_name_app3  {
              server   127.0.0.1:8088          max_fails=3  fail_timeout=30s;
              server   127.0.0.1:8089          max_fails=3  fail_timeout=30s;
              server   127.0.0.1:8090          max_fails=3  fail_timeout=30s;
              server   127.0.0.1:8091 backup;  
            } 

希望能帮助到你。

于 2013-04-29T22:25:27.467 回答
0

人们正在寻找 Nginx 的替代方案:为每个 Meteor 应用程序安装 Cluster 包,该包将自动处理负载平衡。https://github.com/meteorhacks/cluster

如何设置:

# You can use your existing MONGO_URL for this
export CLUSTER_DISCOVERY_URL=mongodb://host:port/db,
# this is the direct URL to your server (it could be a private URL)
export CLUSTER_ENDPOINT_URL=http://ipaddress
# mark your server as a web service (you can set any name for this)
export CLUSTER_SERVICE=web

示例设置:

{
  "ip-1": {
    "endpointUrl": "http://ip-1",
    "balancerUrl": "https://one.bulletproofmeteor.com"
  },
  "ip-2": {
    "endpointUrl": "http://ip-2",
    "balancerUrl": "https://two.bulletproofmeteor.com"
  },
  "ip-3": {
    "endpointUrl": "http://ip-3",
    "balancerUrl": "https://three.bulletproofmeteor.com"
  },
  "ip-4": {
    "endpointUrl": "http://ip-4"
  }
}
于 2016-05-26T11:42:10.907 回答