質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.48%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

nginx

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Amazon EC2

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

2回答

813閲覧

AWS EC2 + nginx + laravel6環境にて、public内のindex.phpが表示されない

yuzu0228

総合スコア4

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

nginx

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Amazon EC2

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2020/05/14 00:13

前提・実現したいこと

実行環境:AWS EC2, nginx/1.16.1, PHP7.3.16, Laravel6

AWS EC2にてLaravelプロジェクト内のpublic/index.phpファイルが表示されず、nginxの404 not foundが表示されてしまいます。

また、publicフォルダに配置したphpinfo.phpとindex.htmlは正しく表示されました。

/etc/nginx/nginx.confファイルは以下のように記述してあります。

nginx.conf

以下、抜粋 events { worker_connections 1024; } http { 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; tcp_nodelay on; keepalive_timeout 65; types_hash_max_size 2048; include /etc/nginx/mime.types; default_type application/octet-stream; # Load modular configuration files from the /etc/nginx/conf.d directory. # See http://nginx.org/en/docs/ngx_core_module.html#include # for more information. include /etc/nginx/conf.d/*.conf; server { listen 80 default_server; listen [::]:80 default_server; server_name _; root /var/www/laravel-bool-reviw/public; # Load configuration files for the default server block. include /etc/nginx/default.d/*.conf; location / { try_files $uri $uri/ /index.php?query_string; } error_page 404 /404.html; location = /40x.html { } error_page 500 502 503 504 /50x.html; location = /50x.html { } }

確認したこと

web.phpのルーティング設定は確認しています。

ディレクトリパーミッションは以下のようになっています。

drwxrwxr-x 2 ec2-user ec2-user 89 May 11 09:54 css -rw-rw-r-- 1 ec2-user ec2-user 0 May 5 06:22 favicon.ico drwxrwxr-x 2 ec2-user ec2-user 55 May 11 09:54 images -rw-r--r-- 1 root root 128 May 13 22:12 index.html -rw-rw-r-- 1 ec2-user ec2-user 1823 May 5 06:22 index.php drwxrwxr-x 2 ec2-user ec2-user 64 May 11 09:54 js -rw-rw-r-- 1 ec2-user ec2-user 35 May 5 06:22 mix-manifest.json -rw-rw-r-- 1 ec2-user ec2-user 19 May 12 08:53 phpinfo.php -rw-rw-r-- 1 ec2-user ec2-user 24 May 5 06:22 robots.txt lrwxrwxrwx 1 ec2-user ec2-user 46 May 5 17:02 storage -> /var/www/laravel-boo l-reviw/storage/app/public -rw-rw-r-- 1 ec2-user ec2-user 1194 May 5 06:22 web.config

/var/log/nginx/error.logには以下のようなエラーメッセージが記述されていました。

2020/05/xx xx:xx:xx [error] 3422#0: *47 open() "/var/www/laravel-bool-reviw/public/50x.html" failed (2: No such file or directory), client: xxx.xx.xx.xxx, server: _, request: "GET / HTTP/1.1", upstream: "fastcgi://unix:/run/php-fpm/www.sock", host: "xx.xxx.xxx.xxx:xx"

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

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

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

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

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

guest

回答2

0

自己解決しました。

問題はlaravel側に問題があったみたいで、単なるプログラムの設計ミスでした。

ただ今回の一件でわかったことは、本番環境(EC2, nginx)のデフォルト設定では、laravel側にエラーがあった場合強制的に404 not foundページが表示されるようなので、laravel側のエラーに気づきにくいかもしれないです。(おそらく本番環境でのセキュリティーを考慮しているのかな?)

その場合はlaravelプロジェクト配下の/storage/logsディレクトリにあるエラーログを参照すれば良いかと。

投稿2020/05/17 22:52

yuzu0228

総合スコア4

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

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

0

自己解決

自己解決しました。

問題はlaravel側に問題があったみたいで、単なるプログラムの設計ミスでした。

ただ今回の一件でわかったことは、本番環境(EC2, nginx)のデフォルト設定では、laravel側にエラーがあった場合強制的に404 not foundページが表示されるようなので、laravel側のエラーに気づきにくいかもしれないです。(おそらく本番環境でのセキュリティーを考慮しているのかな?)

その場合はlaravelプロジェクト配下の/storage/logsディレクトリにあるエラーログを参照すれば良いかと。

投稿2020/05/17 22:43

yuzu0228

総合スコア4

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問