5

そのため、NGINX は私の Rails アプリでうまく機能していますが、静的/動的混合環境の構成を正しく設定するのに少し役立つと思います。これは API なので、基本的には次のとおりです。

  1. public/index.html を提供してください。「API へようこそ」という単一の静的 html ページのコントローラーを作成するのはばかげているからです。
  2. blah.com/doc の /app/doc からドキュメントを提供します
  3. 他のすべてのリクエストをプロキシに提供します。

現在、場所/ try_filesなどが互いに押しつぶされていることはわかっていますが、順列の山を試してみましたが、一度にすべてを機能させることはできません. :)

upstream ss-api {   server unix:/tmp/ss-api.socket fail_timeout=0; }

server {
    listen 80 default deferred;
    server_name localhost;
    access_log /var/log/nginx/api_access.log;

    location {
        root /home/deployer/apps/api/current/public;
        try_files $uri/index.html $uri.html $uri @ss-api;
    }

    location /doc/ {
        root /home/deployer/apps/ss-api/current/doc;
    }

    location @ss-api {
        proxy_pass  http://ss-api;
        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       4G;
        client_body_buffer_size    128k;
        keepalive_timeout 5;
        error_page 500 502 503 504 /500.html;

        proxy_connect_timeout      90;
        proxy_send_timeout         90;
        proxy_read_timeout         90;

        proxy_buffer_size          4k;
        proxy_buffers              4 32k;
        proxy_busy_buffers_size    64k;
        proxy_temp_file_write_size 64k;
    }
}
4

0 に答える 0