Laravel.log 文件写入的问题

Laravel.log 文件写入的问题

项目使用 root 账户部署到服务器后,访问返回 500 错误。

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

  1. 查看 nginx 错误日志
  2. 查看 php 错误日志
  3. 代码中断点测试是否能访问

在错误日志中没有找到踪迹,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 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值