這篇文章將為大家詳細(xì)講解有關(guān)如何解決Laravel日志文件寫入失敗問(wèn)題,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)從2013年創(chuàng)立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站建設(shè)、做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元聶拉木做網(wǎng)站,已為上家服務(wù),為聶拉木各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18980820575
在講這個(gè)問(wèn)題之前可能需要簡(jiǎn)單介紹下 Linux系統(tǒng)下的文件的Ownership和Permission。
?Ownership
?User
User是文件的所有者,默認(rèn)情況下,用戶創(chuàng)建了一個(gè)文件,該文件的所有者就是該用戶。
?Group
一個(gè)用戶組能包含多個(gè)用戶,所有屬于這個(gè)組的用戶都有相同的權(quán)限來(lái)訪問(wèn)文件。假設(shè)你有一個(gè)項(xiàng)目,很多用戶都需要訪問(wèn)這個(gè)項(xiàng)目文件的權(quán)限,你不需要手動(dòng)賦予這些用戶所有權(quán)限,你只需要把這些用戶加到一個(gè)組里面,賦予這些組有訪問(wèn)文件的權(quán)限,這樣一來(lái)就僅僅只有組里面的成員能對(duì)文件進(jìn)行讀寫操作。
?Other
任何其他的用戶都能訪問(wèn)文件,因此,給Other用戶賦予權(quán)限,相當(dāng)于所有用戶都擁有這個(gè)權(quán)限。
?Permission
在 UNIX/ Linux 系統(tǒng)中每一個(gè)文件和目錄都有3中權(quán)限,以下就是對(duì)三個(gè)所有者的討論。
?Read:這個(gè)權(quán)限賦予你打開和讀取文件的權(quán)限。擁有目錄的讀權(quán)限,你能列出其內(nèi)容。
?Write:擁有了讀權(quán)限,你能修改文件的內(nèi)容。擁有了目錄的寫權(quán)限,你能添加、移除以及重命名該目錄下的文件??紤]一種場(chǎng)景,當(dāng)你擁有文件的寫權(quán)限,但是沒有文件存儲(chǔ)目錄的寫權(quán)限,你還是能修改文件的內(nèi)容,但不能重命名、移動(dòng)以及移除目錄下的文件。
?Execute:在Windows系統(tǒng)中,一個(gè)可執(zhí)行的程序通常都有.exe后綴,你能很方便的運(yùn)行它。在 UNIX/Linux 中,除非被賦予可執(zhí)行權(quán)限,否則你將不能運(yùn)行該程序。如果未授權(quán)可執(zhí)行權(quán)限,你讓然可以看并修改程序代碼(被授予讀和寫權(quán)限),但是無(wú)法運(yùn)行它。
linux下文件信息的顯示截圖
linux下目錄的信息顯示截圖
以上的截圖顯示了一個(gè)文件和文件夾的信息,我們可以看到:
?r 代表可讀, w 代表可寫, x 代表可執(zhí)行。
?第一位文件顯示 - ,文件顯示 d 。
?上面第一張圖片, rw-rw-r-— 中。第一組 rw- 表示文件的所有者對(duì)文件有可讀、可寫、不可執(zhí)行的權(quán)限。第二組 rw- 表示文件所屬的組內(nèi)用戶對(duì)該文件有可讀、可寫、不可執(zhí)行的權(quán)限。第三組 r-— 表示其他任何用戶對(duì)該文件有可讀、不可寫、不可執(zhí)行的權(quán)限。
?rw-rw-r-- 用二進(jìn)制表示為 664 ,每一位如有權(quán)限則為 1 ,否則為 0 ,第一個(gè)三位 rw- 用二進(jìn)制表示為 110 轉(zhuǎn)化為十進(jìn)制就是 6,后面兩組依次類推,最后得到 664 。
?上面第一張圖片的 dior www-data 表示該文件的所有者是 dior 用戶,文件屬于 www-data 組。
我們知道很多應(yīng)用系統(tǒng)中的日志是寫文件的,且是以日期來(lái)命名文件的。所以第一次創(chuàng)建日志的用戶就顯得尤為重要,如果文件創(chuàng)建的 Onwer和 Group 不對(duì),其他的用戶觸發(fā)寫入日志文件就會(huì)失敗。
接下來(lái)我們討論下有多少種不同的用戶可能創(chuàng)建日志文件:
?Crontab中執(zhí)行的定時(shí)任務(wù),跟創(chuàng)建 Crontab 的用戶有關(guān),此時(shí)創(chuàng)建的文件 Owner 和 Group 值分別是該用戶以及默認(rèn)的 Group 。
?一些常駐的后臺(tái)進(jìn)程,比如Laravel中的 queue work ,此時(shí)創(chuàng)建的日志文件 Owner 和 Group 值分別是執(zhí)行該進(jìn)程的用戶以及所屬的默認(rèn) Group 。
?正常用戶訪問(wèn)網(wǎng)站產(chǎn)生的日志文件,此時(shí)創(chuàng)建的日志文件的 Owner 和 Group 都是 www-data , www-data 用戶是web服務(wù)器默認(rèn)的用戶。
由以上的分析,我們大概已經(jīng)找到了解決問(wèn)題的方法。
?執(zhí)行用戶創(chuàng)建日志文件的權(quán)限為 664 比較恰當(dāng),這就需要當(dāng)前用戶的umask為 0002 。
?當(dāng)前執(zhí)行用戶的默認(rèn) Group 應(yīng)該設(shè)置為 www-data 。
下面就說(shuō)下我的具體解決方案:
指定www-data用戶執(zhí)行crontab:
sudo crontab -u www-data -e Laravel中修改創(chuàng)建日志文件的權(quán)限: 編輯 confog/logging.php 文件 添加 'permission' => 0664 'daily' => [ 'driver' => 'daily', 'path' => storage_path('logs/laravel.log'), 'level' => 'debug', 'days' => 14, 'permission' => 0664, ],
關(guān)于“如何解決Laravel日志文件寫入失敗問(wèn)題”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。