首页 > 编程 > PHP > 正文

如何解决Laravel.log 文件写入的问题

2020-03-22 16:52:47
字体:
来源:转载
供稿:网友
Laravel.log 文件写入的问题项目使用 root 账户部署到服务器后,访问返回 500 错误。

出现问题后首先按照以下思路查找问题:

查看 nginx 错误日志

查看 php 错误日志

代码中断点测试是否能访问

在错误日志中没有找到踪迹,500 错误通常是代码错误导致的,确认是否打开 laravel 的调试功能:

# 查看 .envAPP_DEBUG=true

设置后页面上显示错误信息:日志文件无权限写入。这是因为日志文件的所有者、用户组都是 root,权限默认是 755,导致非 root 的其他用户无法写入。

查看写入者

执行以下命令查看 php-fpm 的所有者:

ps -ef | grep php-fpm

返回信息:

apache 9520 11965 0 May25 ? 00:02:11 php-fpm: pool wwwapache 10437 11965 0 May26 ? 00:02:10 php-fpm: pool wwwroot 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 appdrwxr-xr-x 6 root root 4096 Jul 12 10:58 frameworkdrwxr-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系统)

laravel的路由(router)图文详解

什么是中间件?听妙绝师太趣说laravel中间件(图)

以上就是如何解决Laravel.log 文件写入的问题的详细内容,PHP教程

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表