導讀 | 用過Laravel的小夥伴一開始安裝完框架後可能都遇到過daily 日誌文件寫入失敗的問題,接下來咱們就來詳細說下日誌文件寫入失敗的緣由以及對應的解決方案。 |
在講這個問題以前可能須要簡單介紹下Linux系統下的文件的Ownership和Permission。php
•Ownershiphtml
◦Userlinux
User是文件的全部者,默認狀況下,用戶建立了一個文件,該文件的全部者就是該用戶。laravel
◦Groupweb
一個用戶組能包含多個用戶,全部屬於這個組的用戶都有相同的權限來訪問文件。假設你有一個項目,不少用戶都須要訪問這個項目文件的權限,你不須要手動賦予這些用戶全部權限,你只須要把這些用戶加到一個組裏面,賦予這些組有訪問文件的權限,這樣一來就僅僅只有組裏面的成員能對文件進行讀寫操做。服務器
◦Other框架
任何其餘的用戶都能訪問文件,所以,給Other用戶賦予權限,至關於全部用戶都擁有這個權限。網站
•Permissiondebug
在 UNIX/Linux 系統中每個文件和目錄都有3中權限,如下就是對三個全部者的討論。日誌
linux下文件信息的顯示截圖
linux下目錄的信息顯示截圖
以上的截圖顯示了一個文件和文件夾的信息,咱們能夠看到:
咱們知道不少應用系統中的日誌是寫文件的,且是以日期來命名文件的。因此第一次建立日誌的用戶就顯得尤其重要,若是文件建立的 Onwer和 Group 不對,其餘的用戶觸發寫入日誌文件就會失敗。
接下來咱們討論下有多少種不一樣的用戶可能建立日誌文件:
由以上的分析,咱們大概已經找到了解決問題的方法。
下面就說下個人具體解決方案:
指定www-data用戶執行crontab:
sudo crontab -u www-data -e Laravel中修改建立日誌文件的權限: 編輯 confog/logging.php 文件 添加 'permission' => 0664 'daily' => [ 'driver' => 'daily', 'path' => storage_path('logs/laravel.log'), 'level' => 'debug', 'days' => 14, 'permission' => 0664, ],
原文來自: https://www.linuxprobe.com/laravel-permission-denied.html