🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
unicorn

Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

HTTPS

HTTPS(Hypertext Transfer Protocol Secure)はHypertext Transfer プロトコルとSSL/TLS プロトコルを組み合わせたものです。WebサーバとWebブラウザの間の通信を暗号化させて、通信経路上での盗聴や第三者によるなりすましを防止します。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

SSL

SSL(Secure Sockets Layer)とは、暗号化されたプロトコルで、インターネット上での通信セキュリティを提供しています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

Q&A

解決済

2回答

985閲覧

NginxとUnicornでhttps通信する際、アプリの画面が表示されない

taba.3011

総合スコア12

unicorn

Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

HTTPS

HTTPS(Hypertext Transfer Protocol Secure)はHypertext Transfer プロトコルとSSL/TLS プロトコルを組み合わせたものです。WebサーバとWebブラウザの間の通信を暗号化させて、通信経路上での盗聴や第三者によるなりすましを防止します。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

SSL

SSL(Secure Sockets Layer)とは、暗号化されたプロトコルで、インターネット上での通信セキュリティを提供しています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

0グッド

0クリップ

投稿2021/03/05 05:04

前提・実現したいこと

https通信でブラウザにアプリを表示させたいです。
現状https通信をするとnginxのテストページが表示されてしまいます。http通信の時はアプリが表示されます。
nginxの設定ファイルにunicornと連携する記述をしているはずなのですが、一向にブラウザでnginxの画面しか表示されず困っています。

該当のソースコード

config/unicorn.rb

app_path = File.expand_path('../../', __FILE__) worker_processes 1 working_directory app_path pid "#{app_path}/tmp/pids/unicorn.pid" listen "#{app_path}/tmp/sockets/unicorn.sock" stderr_path "#{app_path}/log/unicorn.stderr.log" stdout_path "#{app_path}/log/unicorn.stdout.log" timeout 60 preload_app true GC.respond_to?(:copy_on_write_friendly=) && GC.copy_on_write_friendly = true check_client_connection false run_once = true before_fork do |server, worker| defined?(ActiveRecord::Base) && ActiveRecord::Base.connection.disconnect! if run_once run_once = false # prevent from firing again end old_pid = "#{server.config[:pid]}.oldbin" if File.exist?(old_pid) && server.pid != old_pid begin sig = (worker.nr + 1) >= server.worker_processes ? :QUIT : :TTOU Process.kill(sig, File.read(old_pid).to_i) rescue Errno::ENOENT, Errno::ESRCH => e logger.error e end end end after_fork do |_server, _worker| defined?(ActiveRecord::Base) && ActiveRecord::Base.establish_connection end

etc/nginx/conf.d/rails.conf

server { listen 80; server_name stockapp.work; client_max_body_size 2g; root /var/www/stock-info/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://app_server; } error_page 500 502 503 504 /500.html; } server { listen 443 ssl; server_name stockapp.work; # root /var/www/stock-info/public; # ssl_certificate /etc/nginx/ssl/stock.crt; # ssl_certificate_key /etc/nginx/ssl/stock.pem; # ssl_session_cache shared:SSL:1m; ssl_session_timeout 5m; # ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; # location / { root /var/www/stock-info/public; # index index.html index.htm; } 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-Proto $scheme; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_redirect off; proxy_pass http://app_server; } error_page 500 502 503 504 /500.html; }

試したこと

https://github.com/defunkt/unicorn/blob/master/examples/nginx.conf

元々うまくいっていたunicornと連携する記述をhttps通信の記述の場所にコピーしました。
また、上記のソースコードでは、https通信をする際はproxy_set_header X-Forwarded-Proto $scheme;という記述をする必要があるとあったので追記してみましたが、変化はありませんでした。
https通信をするにあたって、unicornの設定ファイルのどこかを変更したり、nginxのhttps設定の記述をどこか変更しなければならないのでしょうか...?
お詳しい方がいらっしゃいましたらご教授ください。

補足情報(FW/ツールのバージョンなど)

unicorn v5.8.0
nginx/1.18.0
ruby 2.6.5p114 (2019-10-01 revision 67812) [x86_64-linux]
Rails 6.0.3.5
OS:Amazon Linux2

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

443側の設定にのみ location / ディレクティブがあるのが気になります。

location / { root /var/www/stock-info/public; # index index.html index.htm; }

投稿2021/03/05 07:32

yukky1201

総合スコア2751

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

taba.3011

2021/03/05 09:22

yukky1201様回答ありがとうございます。 rootパスを、locationの中に書いても外に書いても結果が変わらなかったので、なんとなくでlocationに記述していました。ただyukky1201様に指摘され、locationについて調べてみたところ、locationはパスごとの設定をすることがわかりました。 そのためlocationにアプリのパスを指定して、その中にrootの設定を記述したところ上手くいきました! 参考記事ではこんなことせずとも上手くいっているので、今回の自分のやり方があっているのかどうかわかりませんが、指摘してくださったお陰で解決につながりました!ありがとうございます!
guest

0

自己解決

location ドメイン名 { root /var/www/stock-info/public; index index.html index.htm; }

このように設定したらブラウザ上でアプリが表示されました!

投稿2021/03/05 09:11

taba.3011

総合スコア12

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問