文章詳情頁
apache 如何記錄日志
瀏覽:156日期:2024-06-27 18:43:36
問題描述
在linux系統上,apache是以www-data(默認)用戶運行的,同時其用戶組也是www-data。
可是我發現apache的日志目錄/var/log/apache是屬于root的,組是adm
www-data對該日志目錄是沒有寫權限的,而且它不是adm組的用戶,甚至連讀權限都沒有。
但是我們發現有一個apache2進程是以root運行的,應該是主進程。難道所有子進程的日志都是先通過進程通信傳遞給主進程,然后再記錄的嗎?還是說有其他什么機制。
問題解答
回答1:我這里沒有 Apache httpd,所以自己寫程序試了試。在 write 時是不檢查權限的,也就是說只要日志文件打開成功了,那么再改變用戶 ID(setuid)之后依舊可以向該文件寫入數據。當然這樣子的話,如何重新打開日志文件是個問題。你直接去看 Apache httpd 的源碼就好。簡單地 strace 一下也許會有發現。
相關文章:
1. 淺談vue生命周期共有幾個階段?分別是什么?2. index.php錯誤,求指點3. 視頻 - html5 video的autoplay 在智能手機上不運作?4. javascript - 百度坐標,返回目標附近有哪些坐標5. css3 - 使用less編譯css后,后期的項目中less是直接放在項目文件中,后期如何維護呢6. css3 - 在css里面,樣式不生效問題7. node.js - 在阿里云搭建vue環境后npm run dev 沒有看到vue歡迎頁面而是 UnhandledPromiseRejection8. javascript - Jquary的contains如何做到精準匹配9. html5 - 前端面試碰到了一個緩存數據的問題,來論壇上請教一下10. javascript - ui-router AngularJS url顯示正常 頁面沒有變化?
排行榜
