🎄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、上で動作します。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Q&A

解決済

1回答

3358閲覧

RailsアプリをHTTPS化して公開したい(ブラウザ上で 403 Forbidden nginx /1.16.1)

begenner

総合スコア80

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、上で動作します。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

0グッド

0クリップ

投稿2019/10/17 06:03

編集2019/10/17 07:01

現在AWS(amazon linux2)にRailsアプリをデプロイし、nginxの設定をしています。

を参考にElasticIPを叩いてRailsアプリが動作しているのが確認できたので、
下記の2記事1セットで AWS + Rails + HTTPS に対応していそうな

  1. [Rails][Nginx][AWS] Let's EncryptをEC2上のRailsに入れてHttpsにする - Qiita
  2. Amazon Linux2とLet's EncryptでSSL対応サーバを0から爆速構築 - Qiita

を参考にしました。
しかし上記タイトルのエラーが発生したため、

などの他のサイトを参考にしようとしましたが

  • 設定がどれも微妙に違う
  • 添削の仕方がわからない(nginxに関しては初心者です)

であるためnginxの設定ファイルをどのように編集すればいいか全くわかりません(m_ m)
もしわかる方がいらっしゃればご教授いただきますようよろしくお願いいたします(m
_m)

動作環境

Rails

  • Ruby: 2.4.5
  • Rails: 4.2.11.1
  • nginx: 1.16.1

AWS

  • Amazon linux2
  • EC2、RDS(MySQL)
  • Route53設定済

ドメイン

  • freenom(Route53と紐付け済)

証明書

  • Let'sEncrypt

エラー内容

  • nginx を再起動してブラウザにアクセスするとnginx 403 Forbiddenが表示される
  • /var/www/rails/webapp/log/nginx.error.logを確認すると下記のエラーが表示されている

bash

1[error]: *1 directory index of "/var/www/rails/【webapp】/public/" is forbidden, client: 【my_global_ip】, server: 【myDomain】, request: "GET / HTTP/1.1", host: "【myDomain】"

期待する動作

nginxのエラーがなくなり、AWS上のRailsアプリが登録済ドメインでHTTPS規格で動作すること

補足

下記の語句は置き換えてあります

  • Railsのアプリ名: 【webapp】
  • 取得済みのドメイン: 【myDomain】
  • 自分のグローバルIP: 【my_global_ip】

フォルダの権限は下記の通りです

bash

1[username@x-x-x-x ~]$ cd /;ls -al 2合計 16 3: 4drwxr-xr-x 20 username username 280 104 13:44 var 5 6 7[username@x-x-x-x /]$ cd /var/;ls -la 8合計 12 9: 10drwxr-xr-x 4 username username 38 1014 17:45 www 11 12 13[username@x-x-x-x var]$ cd www/;ls -la 14合計 0 15: 16drwxr-xr-x 3 username username 43 104 14:12 rails 17[ 18 19username@x-x-x-x www]$ cd rails/;ls -la 20合計 4 21: 22drwxr-xr-x 15 username username 302 1014 14:03 【webapp】 23 24 25[username@x-x-x-x rails]$ cd 【webapp】/;ls -la 26合計 40 27drwxr-xr-x 5 username username 134 104 23:09 public 28

該当しそうなコード

  • (1 / 2) /etc/nginx/conf.d/【webapp】.conf

bash

1# /etc/nginx/conf.d/【webapp】.conf 2 3# log directory 4error_log /var/www/rails/【webapp】/log/nginx.error.log; 5access_log /var/www/rails/【webapp】/log/nginx.access.log; 6 7upstream app_server { 8 # for UNIX domain socket setups 9 server unix:/var/www/rails/【webapp】/tmp/sockets/.unicorn.sock fail_timeout=0; 10} 11 12server { 13 listen 443 ssl; 14 15 server_name 【myDomain】; 16 17 keepalive_timeout 5; 18 client_max_body_size 2G; 19 20 # path for static files 21 root /var/www/rails/【webapp】/public; 22 # root /var/www/rails/【myDomain】/public; 23 24 # page cache loading 25 try_files $uri/index.html $uri @app; 26# try_files $uri/index.html $uri @app $uri @app_server; 27 28 location @app { 29 proxy_set_header X-Real-IP $remote_addr; 30 proxy_set_header X-Forwarded-Proto $scheme; 31 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 32 proxy_set_header Host $http_host; 33 } 34 35 # Railsエラーページ 36 error_page 500 502 503 504 /500.html; 37 38 location = /500.html { 39 root /var/www/rails/【webapp】/public; 40 } 41 42# location ^~ /.well-known/acme-challenge/ { 43# root /var/www/letsencrypt-webroot; 44# } 45 # listen 443 ssl; # managed by Certbot 46 ssl_certificate /etc/letsencrypt/live/【myDomain】/fullchain.pem; # managed by Certbot 47 ssl_certificate_key /etc/letsencrypt/live/【myDomain】/privkey.pem; # managed by Certbot 48 include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot 49 ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot 50 51} 52 53#server { 54# listen 80; 55# server_name 【myDomain】; 56# return 301 https://$host$request_uri; 57#}
  • (2 / 2)/etc/nginx/nginx.conf

bash

1# /etc/nginx/nginx.conf 2# For more information on configuration, see: 3# * Official English Documentation: http://nginx.org/en/docs/ 4# * Official Russian Documentation: http://nginx.org/ru/docs/ 5 6user nginx; 7worker_processes auto; 8error_log /var/log/nginx/error.log; 9pid /run/nginx.pid; 10 11# Load dynamic modules. See /usr/share/doc/nginx/README.dynamic. 12include /usr/share/nginx/modules/*.conf; 13 14events { 15 worker_connections 1024; 16} 17 18http { 19 log_format main '$remote_addr - $remote_user [$time_local] "$request" ' 20 '$status $body_bytes_sent "$http_referer" ' 21 '"$http_user_agent" "$http_x_forwarded_for"'; 22 23 access_log /var/log/nginx/access.log main; 24 25 sendfile on; 26 tcp_nopush on; 27 tcp_nodelay on; 28 keepalive_timeout 65; 29 types_hash_max_size 2048; 30 31 include /etc/nginx/mime.types; 32 default_type application/octet-stream; 33 34 # Load modular configuration files from the /etc/nginx/conf.d directory. 35 # See http://nginx.org/en/docs/ngx_core_module.html#include 36 # for more information. 37 include /etc/nginx/conf.d/*.conf; 38 39 40 server { 41 listen 80 default_server; 42 listen [::]:80 default_server; 43 #server_name _; 44 server_name 【myDomain】; 45 # Load configuration files for the default server block. 46 include /etc/nginx/default.d/*.conf; 47 48 location / { 49 try_files $uri/index.html $uri @unicorn; 50 } 51 52 error_page 404 /404.html; 53 location = /40x.html { 54 } 55 56 error_page 500 502 503 504 /50x.html; 57 location = /50x.html { 58 } 59 } 60 61# Settings for a TLS enabled server. 62# 63# server { 64# listen 443 ssl http2 default_server; 65# listen [::]:443 ssl http2 default_server; 66# server_name _; 67# root /usr/share/nginx/html; 68# 69# ssl_certificate "/etc/pki/nginx/server.crt"; 70# ssl_certificate_key "/etc/pki/nginx/private/server.key"; 71# ssl_session_cache shared:SSL:1m; 72# ssl_session_timeout 10m; 73# ssl_ciphers HIGH:!aNULL:!MD5; 74# ssl_prefer_server_ciphers on; 75# 76# # Load configuration files for the default server block. 77# include /etc/nginx/default.d/*.conf; 78# 79# location / { 80# } 81# 82# error_page 404 /404.html; 83# location = /40x.html { 84# } 85# } 86 87}

追記1

別サイトで教えていただいた内容

/etc/nginx/conf.d/【webapp】.conflocation @app 内にproxy_pass http://app_server;を追加する

を反映させるとnginxのエラー内容が

[error] 9028#0: *6 connect() to unix:/var/www/rails/【webapp】/tmp/sockets/.unicorn.sock failed (111: Connection refused) while connecting to upstream, client: 【my_global_ip】, server: 【myDomain】, request: "GET / HTTP/1.1", upstream: "http://unix:/var/www/rails/【webapp】/tmp/sockets/.unicorn.sock:/", host: "【myDomain】"

に変わりました。

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

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

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

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

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

guest

回答1

0

ベストアンサー

Rails + AWS + nginxでエラー(nginx: [warn] duplicate value "TLSv1.2" in /etc/nginx/conf.d/webapp.conf)

ほうに書いた回答ですが、下記の順番に動作確認すると切り分けできていくと思います
1.httpでwebサイトが表示される
2.httpでRailsが動く
3.httpsでwebサイトが表示される
4.httpsでRailsが動く

また、proxy_pass http://app_server;が無いのでは?と指摘しましたが、SSL環境なのでproxy_pass https://app_server;となるのかもしれません。

投稿2019/10/17 07:21

yukky1201

総合スコア2751

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

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

begenner

2019/10/18 03:11

遅くなってすいません(m_ _m) proxy_pass http://app_server でおかげさまで期待通りの動作をしてくれるようになりました!! Railsのエラー画面に関しては unicorn の設定ファイルを一時隔離していたのでunicornの自動起動ができていませんでした(m_ _m) ありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問