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

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

ただいまの
回答率

88.62%

nginxで500エラーが帰ってきてしまう。

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 5,984

T.FUJII

score 21

前提・実現したいこと

500エラーを何とかしたいです。

[crome画面上]
このページは動作していません
27.133.152.201 では現在このリクエストを処理できません。
HTTP ERROR 500

全体の流れ

itの新人です。お手柔らかにお願いします(T_T)

作成したlaravelアプリケーションをSCPでsakuracloudのサーバーに送り、その後ipアドレスでそのサイトを見ようとすると500エラーが帰ってきてしまいます。デプロイヤーなどを使わずに、WinSCPで古いプロジェクトを削除し、新しいプロジェクトを配置しました。当初はバージョンアップ前のアプリが配置されており、そのアプリは動いていました。新しく本番環境に移した最新版アプリ(ファイル名、階層などすべて同じもの)では500エラーが帰ってきてしまいお手上げ状態になってしまいました。

また、nginx.confでのserver{}が間違っているのではないかと、nginx.confのserver{}を削除しました。(includeで /etc/nginx/conf.d/*.conf; を呼んでいて、その中のserver{}と設定が重複しているように思えたため。

初心者なのでわからないですが、yumでnginxを入れ、yum-cronで自動アップデートを(apply_updates = yes)としていて中のconfが書き換わるようなことがあるのでしょうか?以前はdefault.confとしていたはずのものがdefault.comf.rpmsaveとなっていたので、default.confに戻しました。

composer installも行いました。

$ composer install
Loading composer repositories with package information
Installing dependencies (including require-dev) from lock file
Nothing to install or update
Generating autoload files

発生している問題・エラーメッセージ

下記のエラーが発生しました

【/var/log/nginx/access.log】

114.179.83.214 - - [30/Mar/2018:15:40:43 +0900] "GET / HTTP/1.1" 500 5 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.181 Safari/537.36" "-"

追記(CHERRY様)
【/var/log/nginx/error.log】

PHP message: PHP Fatal error:  Uncaught ErrorException: file_put_contents(/var/www/html/scraping/storage/framework/views/0c34c98ae8b1ae9acd904b0fab9fcc1606801835.php): failed to open stream: Permission denied in /var/www/html/scraping/vendor/laravel/framework/src/Illuminate/Filesystem/Filesystem.php:122
Stack trace:
#0 [internal function]: Illuminate\Foundation\Bootstrap\HandleExceptions->handleError(2, 'file_put_conten...', '/var/www/html/s...', 122, Array)
#1 /var/www/html/scraping/vendor/laravel/framework/src/Illuminate/Filesystem/Filesystem.php(122): file_put_contents('/var/www/html/s...', '<?php\n    $titl...', 0)
#2 /var/www/html/scraping/vendor/laravel/framework/src/Illuminate/View/Compilers/BladeCompiler.php(121): Illuminate\Filesystem\Filesystem->put('/var/www/html/s...', '<?php\n    $titl...')
#3 /var/www/html/scraping/vendor/laravel/framework/src/Illuminate/View/Engines/CompilerEngine.php(51): Illuminate\View\Compilers\BladeCompiler-
(END)

該当のソースコード

【etc/nginx/conf.d/default.conf】

# /var/www/html/scraping/public がlaravelのプロジェクトのルートの場合
server{
   # fastcgi_paramの$document_rootが正しく設定されるようにここでrootの設定
   root   /var/www/html/scraping/public;

   location / {
       index  index.php index.html index.htm;
       try_files $uri $uri/ /index.php?$query_string;
   }

   location ~ \.php$ {
       # fastcgi_passは/etc/php-fpm.d/www.confのlistenで指定したパス
       # unix:を忘れない、権限がないと色々エラーが起きる
       fastcgi_pass   unix:/var/run/php-fpm/php-fpm.sock;
       fastcgi_index  index.php;
       fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
       include        fastcgi_params;
   }
}

【etc/nginx/nginx.conf】

# For more information on configuration, see:
#   * Official English Documentation: http://nginx.org/en/docs/
#   * Official Russian Documentation: http://nginx.org/ru/docs/

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

# Load dynamic modules. See /usr/share/nginx/README.dynamic.
include /usr/share/nginx/modules/*.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;

# Settings for a TLS enabled server.
#
#    server {
#        listen       443 ssl http2 default_server;
#        listen       [::]:443 ssl http2 default_server;
#        server_name  _;
#        root         /usr/share/nginx/html;
#
#        ssl_certificate "/etc/pki/nginx/server.crt";
#        ssl_certificate_key "/etc/pki/nginx/private/server.key";
#        ssl_session_cache shared:SSL:1m;
#        ssl_session_timeout  10m;
#        ssl_ciphers HIGH:!aNULL:!MD5;
#        ssl_prefer_server_ciphers on;
#
#        # Load configuration files for the default server block.
#        include /etc/nginx/default.d/*.conf;
#
#        location / {
#        }
#
#        error_page 404 /404.html;
#            location = /40x.html {
#        }
#
#        error_page 500 502 503 504 /50x.html;
#            location = /50x.html {
#        }
#    }

}

【/etc/php-fpm.d/www.conf】

 user = apache
 group = apache
 listen = 127.0.0.1:9000
 listen.group = apache
 listen.owner  = apache
上記を下記に
+ user = nginx
+ group = nginx
+ listen = /var/run/php-fpm/php-fpm.sock
+ listen.group  = nginx
+ listen.owner = nginx

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

開発環境:Vagrant + VirtualBox / Homestead
言語:php-7.1.14 (NTS)
フレームワーク:Laravel5.5 (LTS)
サーバー:nginx
DB:MySQL

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • CHERRY

    2018/03/30 16:53

    /var/log/nginx/error.log には、何かメッセージは出ていないでしょうか?

    キャンセル

  • T.FUJII

    2018/03/30 17:03

    追記いたしました。ご確認よろしくお願いいたします。

    キャンセル

  • CHERRY

    2018/03/30 17:09 編集

    エラーメッセージからすると PHP スクリプトで、エラーが出ているようですが... 『PHP Warning: require(/var/www/html/scraping/public/../vendor/autoload.php): failed to open stream: No such file or directory in /var/www/html/scraping/public/index.php on line 24』『PHP Fatal error: require(): Failed opening required '/var/www/html/scraping/public/../vendor/autoload.php' (include_path='.:/usr/share/pear:/usr/share/php') in /var/www/html/scraping/public/index.php on line 24』

    キャンセル

  • T.FUJII

    2018/03/30 17:19

    CHERRY様、Errorの内容が違いました書き換えました。申し訳ございません。

    キャンセル

回答 1

check解決した方法

0

①ディレクトリを移動してcomposer installしていなかった点
https://qiita.com/pugiemonn/items/3d000ac0486987dd92df

②storageのパーミッションを変更(laravel5.5のためprojectの名前/storage)
https://teratail.com/questions/4161

で解決することができました。
お騒がせいたしました。
ご協力いただいたCHERRY様ありがとうございました!

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 88.62%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る