15

我需要一些 linux 大师的帮助。我正在开发一个包含彗星服务器的网络应用程序。Comet 服务器在 localhost:8080 上运行,并公开 url localhost:8080/long_polling 供客户端连接。我的 webapp 在 localhost:80 上运行。

我使用 nginx 将请求从 nginx 代理到彗星服务器(localhost:80/long_polling 代理到 localhost:8080/long_polling),但是,我对这个解决方案有两个不满:

  1. nginx 在一分钟后给我一个 504 网关超时,即使我将每个超时设置更改为 600 秒
  2. 我真的不希望 nginx 必须代理到彗星服务器 - nginx 代理不是为持久连接(可能长达半小时)而构建的。我宁愿让客户端直接连接彗星服务器,让彗星服务器处理。

所以我的问题是:是否有任何 linux 技巧可以让我在不使用 nginx 代理的情况下将 localhost:8080/long_polling 暴露给 localhost:80/long_polling?一定有什么。这就是为什么我认为这个问题可能最好由 linux 大师来回答。

我需要 /long_polling 在端口 80 上公开的原因是我可以使用 AJAX 连接到它(ajax same-origin-policy)。

这是我的 nginx proxy.conf 供参考:

proxy_redirect              off;                                                                                                                         
proxy_set_header            Host $host;
proxy_set_header            X-Real-IP $remote_addr;
proxy_set_header            X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size        10m;
client_body_buffer_size     128k;
proxy_connect_timeout       600;
proxy_send_timeout          600;
proxy_read_timeout          600;
proxy_buffer_size           4k;
proxy_buffers               4 32k;
proxy_busy_buffers_size     64k;
proxy_temp_file_write_size  64k;
send_timeout                600;
proxy_buffering             off;
4

7 回答 7

7

这是我的 nginx.conf 和 proxy.conf。但是请注意,proxy.conf 太过分了——我只是在尝试调试我的程序时设置了所有这些设置。

/etc/nginx/nginx.conf

worker_processes  1;                                                                                                                                     
user www-data;

error_log  /var/log/nginx/error.log debug;
pid        /var/run/nginx.pid;

events {
    worker_connections  1024;
}

http {
    include /etc/nginx/proxy.conf;

    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    access_log  /var/log/nginx/access.log;

    sendfile        on;
    tcp_nopush     on;

    keepalive_timeout  600;
    tcp_nodelay        on;

    gzip  on;
    gzip_comp_level 2;
    gzip_proxied any;
    gzip_types text/plain text/html text/css application/x-javascript text/xml application/xml application/xml+rss text/javascript;

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}

/etc/nginx/proxy.conf

proxy_redirect              off;                                                                                                                         
proxy_set_header            Host $host;
proxy_set_header            X-Real-IP $remote_addr;
proxy_set_header            X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size        10m;
client_body_buffer_size     128k;
proxy_connect_timeout       6000;
proxy_send_timeout          6000;
proxy_read_timeout          6000;
proxy_buffer_size           4k;
proxy_buffers               4 32k;
proxy_busy_buffers_size     64k;
proxy_temp_file_write_size  64k;
send_timeout                6000;
proxy_buffering             off;
proxy_next_upstream error;
于 2009-07-22T19:18:36.517 回答
6

实际上,我现在设法让这个工作。谢谢你们。nginx 504 超时的原因很愚蠢:我没有像这样在我的 nginx.conf 中包含 proxy.conf:

include /etc/nginx/proxy.conf;

所以,我将 nginx 作为 COMET 服务器的前端代理。

于 2009-07-22T15:03:20.093 回答
5

我不认为,这是可能的......

localhost:8080/long_polling是一个URI......更准确地说,它应该是http://localhost:8080/long_polling......在HTTPURI被解析为请求/long_polling,端口80到域'localhost'的服务器......也就是说,打开一个到127.0.0.1的tcp连接:80,并发送

GET /long_polling HTTP/1.1
Host: localhost:8080

加上一些额外的 HTTP 标头...我还没有听说,端口可以跨进程绑定...

实际上,如果我理解得很好,nginx 被设计为一个可扩展的代理......而且,他们声称他们需要 2.5 MB 的 10000 个 HTTP 空闲连接......所以这真的不应该是一个问题......

你用的是什么彗星服务器?你可以让彗星服务器代理一个网络服务器吗?正常的http请求应该被快速处理......

问候

back2dos

于 2009-07-21T17:26:41.670 回答
3

现在有一个用于 Nginx 的 Comet 插件。它可能会很好地解决您的问题。

http://www.igvita.com/2009/10/21/nginx-comet-low-latency-server-push/

于 2009-12-07T22:30:55.153 回答
2

尝试

proxy_next_upstream error;

默认是

proxy_next_upstream error timeout;

超时不能超过 75 秒。

http://wiki.nginx.org/NginxHttpProxyModule#proxy_next_upstream

http://wiki.nginx.org/NginxHttpProxyModule#proxy_connect_timeout

于 2009-07-22T13:18:05.237 回答
0

如果不进行一些严重的TCP/IP 混杂,就不能在同一个 IP 地址上的同一个 TCP 端口上公开两个应用程序。一旦 nginx 开始服务连接,它就不能将它传递给其他应用程序,它只能代理它。

因此,要么使用另一个端口,另一个 IP 号码(可能在同一台物理机器上),要么使用代理。

编辑:我猜 nginx 正在超时,因为它很长时间没有看到任何活动。也许每隔几分钟添加一条空消息可以防止连接失败。

于 2009-07-21T17:49:07.053 回答
0

您可能想在 node.js 服务器上尝试 listen(80) 而不是 8080(我假设您将其用作异步服务器?)并且可能完全错过 Ngnix。我使用连接中间件并表达到服务器静态文件并处理通常由 Ngnix 处理的缓存。如果您想运行多个节点实例(我会建议),您可能希望将 node.js 本身视为其他节点实例的代理/负载均衡器,而不是将 Nginx 作为您的网关。当我一次提供太多静态图像文件时,我遇到了这个问题,但是在我将图像放在 S3 上之后,它就稳定了。Nginx 可能对你正在做的事情有点矫枉过正。试试看。祝你好运。

于 2010-10-18T20:23:24.107 回答