4

私は VPS を持っており、最近、サーバーのセットアップを apache/passenger から nginx/unicorn に移動し、ステージング サーバーを追加しました。サーバーhttp://xxx.xxx.xx.xxに直接アクセスすると、アプリは問題なく起動します。ただし、ステージング サブドメインhttp://staging.myurl.comでヒットすると、404 が返されます。Unicorn に問題があると思われますが、原因がわかりません。

ここに私が持っているものがあります:

/etc/nginx/sites-enabled/codemarks

upstream unicorn {
  server unix:/tmp/unicorn.blog.sock fail_timeout=0;
}

server {
  listen 80 default deferred;
  server_name staging.codemarks.com;
  root /home/deployer/apps/codemarks/current/public;

  location ^~ /assets/ {
    gzip_static on;
    expires max;
    add_header Cache-Control public;
  }

  try_files $uri/index.html $uri @unicorn;
  location @unicorn {
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Host $http_host;
    proxy_redirect off;
    proxy_pass http://unicorn;
  }

  error_page 500 502 503 504 /500.html;
  client_max_body_size 4G;
  keepalive_timeout 10;
}                                                                                                                                                                                                         

次に /etc/hosts で

127.0.0.1       localhost.localdomain   localhost
xxx.xxx.xxx.xxx staging.codemarks.com   staging

サイトの DNS レコードが 1 つあり、ステージングが新しい IP を指すように A レコードを追加しました。また、/var/log/nginx/access.log を調べたところ、直接の (成功した) リクエストがログに記録されますが、staging.codemarks.com yeilds でヒットします

216.21.198.16 - - [26/Dec/2012:14:41:07 -0500] "GET /codemarks HTTP/1.1" 404 446 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_8_0) AppleWebKit/537.20 (KHTML, like Gecko) Chrome/25.0.1337.0 Safari/537.20

私はユニコーンを使用するのが初めてなので、何が欠けているのかわかりません。直接攻撃が成功したので、DNS の問題か、ドメイン固有のユニコーン設定の欠落が疑われますが、壁にぶつかっています。助けてくれてありがとう!

アップデート

/tmp/unicorn.blog.sock は、レールキャストの一部を盗んだため、場違いのようです。ただし、これをユニコーン構成として渡しているため、機能するはずです。

config/unicorn.rb

root = "/home/deployer/apps/codemarks/current"
working_directory root
pid "#{root}/tmp/pids/unicorn.pid"
stderr_path "#{root}/log/unicorn.log"
stdout_path "#{root}/log/unicorn.log"

listen "/tmp/unicorn.blog.sock"
worker_processes 2
timeout 30

unicorn.blog.sock を (盲目的に無意識のうちに) 次のコマンドを実行してセットアップしました。

sudo update-rc.d -f unicorn_blog defaults
4

0 に答える 0