私は 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