Nginx + Unicorn+Railsでアプリを作り、すでにvpsサーバにもアップしております。Seo向上のためのSitemapを作成したのですが、googleのsitemap送信テストを行うと404のエラーが返ってきます。
nginxのエラーログ
$ sudo less error.log-20171203 2017/12/03 11:00:19 [error] 1819#1819: *1 connect() to unix:/var/www/app/sample_app/shared/sockets/unicorn.sock failed (111: Connection refused) while connecting to upstream, client: 00.000.00.20, server: 150.11.111.111, request: "GET /sitemap.xml.gz HTTP/1.1", upstream: "http://unix:/var/www/app/sample_app/shared/sockets/unicorn.sock:/500.html", host: "sample_app.jp"
http://sample.jp/sitemap.xml.gz(一部変更しております)
sitemap.xml.gzはsample_app/public/sitemap.xml.gzのような階層で配置されております。
色々調べたところpublic以下のファイルにアクセスする際にはnginx側で個別の設定をする必要がおそらくあるとのことでした。(sample_app/public/assetsにはアクセスできてます...)
sample_app/public配下全てにアクセスする場合にはどのようにしたら良いのでしょうか?
この件で404が発生した時に/var/log/nginx/error.logにログとして残っていないので、ログ確認できていません。(この問題も気になっています。その他のエラーではしっかり吐かれています)
nginxの設定は以下のようになっております。
$less etc/nginx/nginx.conf
user nginx; worker_processes 1; error_log /var/log/nginx/error.log warn; pid /var/run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 65; gzip on; gzip_vary on; gzip_types text/plain image/png image/jpeg image/gif application/json application/javascript application/x-javascript text/javascript text/xml application/xml application/rss+xml application/atom+xml application/rdf+xml text/css; include /etc/nginx/conf.d/*.conf; }
$ less /etc/nginx/conf.d/local.conf upstream unicorn { server unix:/var/www/app/sample_app/shared/sockets/unicorn.sock; } server { listen 80 default_server; server_name 100.00.006.000; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; root /var/www/app/sample_app; client_max_body_size 100m; error_page 404 /404.html; error_page 500 502 503 504 /500.html; try_files $uri/index.html $uri @unicorn; location @unicorn { 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_pass http://unicorn; } }
robots.txt
User-agent: * Sitemap: http://sample.jp/sitemap.xml.gz
config/environments/production.rb
ruby
1 2Rails.application.configure do 3 4 config.cache_classes = true 5 config.eager_load = true 6 config.consider_all_requests_local = false 7 config.action_controller.perform_caching = true 8 config.read_encrypted_secrets = true 9 10 # Disable serving static files from the `/public` folder by default since 11 # NGINX already handles this. 12 config.public_file_server.enabled = ENV['RAILS_SERVE_STATIC_FILES'].present? 13 14 # Compress JavaScripts and CSS. 15 config.assets.js_compressor = :uglifier 16 # config.assets.css_compressor = :sass 17 18 # Do not fallback to assets pipeline if a precompiled asset is missed. 19 config.serve_static_files = true 20 config.assets.compile = true 21 22 config.log_level = :debug 23 24 config.log_tags = [ :request_id ] 25 config.action_mailer.perform_caching = false 26 config.i18n.fallbacks = true 27 28 if ENV["RAILS_LOG_TO_STDOUT"].present? 29 logger = ActiveSupport::Logger.new(STDOUT) 30 logger.formatter = config.log_formatter 31 config.logger = ActiveSupport::TaggedLogging.new(logger) 32 end 33 34 config.active_record.dump_schema_after_migration = false 35end 36 37 38 39 40
public/assetsにはアクセスできているようなので、該当のファイルをpublic/assetsに配置してしまえば解決できそうなのですが、nginxの勉強も兼ねて実現できたら幸いでございます。
大変お手数おかけしますが、わかる方いましたら助言のほどよろしくお願いいたします。
参考になりそうなもの
・この方と同じ悩みと思われます
・Rails(Apache+Unicorn)で、public以下のディレクトリの中身が404になる場合の解決策
・Rails 4.2以降: Rails+Unicorn で、publicディレクトリの中身が404になる場合の解決策
・sitemapの作成の際の参考記事
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。