如何解决Laravel.log 文件写入的问题
Jul 13, 2018 pm 02:41 PMLaravel.log 文件写入的问题
项目使用 root
账户部署到服务器后,访问返回 500 错误。
出现问题后首先按照以下思路查找问题:
查看 nginx 错误日志
查看 php 错误日志
代码中断点测试是否能访问
在错误日志中没有找到踪迹,500 错误通常是代码错误导致的,确认是否打开 laravel 的调试功能:
# 查看 .env APP_DEBUG=true
设置后页面上显示错误信息:日志文件无权限写入。这是因为日志文件的所有者、用户组都是 root
,权限默认是 755,导致非 root
的其他用户无法写入。
查看写入者
执行以下命令查看 php-fpm 的所有者:
ps -ef | grep php-fpm
返回信息:
apache 9520 11965 0 May25 ? 00:02:11 php-fpm: pool www apache 10437 11965 0 May26 ? 00:02:10 php-fpm: pool www root 11965 1 0 May20 ? 00:07:35 php-fpm: master process (/etc/php-fpm.conf)
第一列就是 php-fpm 的执行用户。
设置日志权限
确认日志目录的权限
ls -l storage/
drwxr-xr-x 3 root root 4096 Jul 11 18:17 app drwxr-xr-x 6 root root 4096 Jul 12 10:58 framework drwxr-xr-x 2 root root 4096 Jul 12 16:17 logs
这里可以发现文件所有者为 root,而 php 作为其他用户只有读和执行权限,没有写入权限。
修改文件权限
# -R 指递归的修改文件夹和此文件夹下所有内容 # 我的 php 是用户 apache 的,请参考自己的情况修改 chown apache storage/logs -R
framework 文件夹也有需要写入的权限,views 层生成的缓存就在其中,可以同时修改掉
chown apache storage/framework -R
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
Laravel开发环境部署之homestead 安装配置过程(windows系统)
Atas ialah kandungan terperinci 如何解决Laravel.log 文件写入的问题. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

PHP vs. Flutter: Pilihan terbaik untuk pembangunan mudah alih

Bagaimana untuk menggunakan pemetaan hubungan objek (ORM) dalam PHP untuk memudahkan operasi pangkalan data?

Analisis kelebihan dan kekurangan alat ujian unit PHP

Perbandingan versi terkini Laravel dan CodeIgniter

Seni bina dan amalan sistem teragih PHP

Bagaimanakah keupayaan pemprosesan data dalam Laravel dan CodeIgniter dibandingkan?

Ujian unit kod PHP dan ujian integrasi
