文章詳情頁
apache 如何記錄日志
瀏覽:159日期: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. docker 17.03 怎么配置 registry mirror ?2. angular.js - angularJS service里面存儲的數據能夠直接和HTML頁面交互嗎?3. 請教各位大佬,瀏覽器點 提交實例為什么沒有反應4. javascript - 七牛接口如何在前端調用?5. css3里rotate怎么實現如圖的效果6. html - chrome 下 transiton translateX(10px) 后字體變化7. javascript - 使用location.href進行頁面跳轉時,并不立即跳轉?8. javascript - 圖片請求失敗怎么去掉左上角的小圖標?9. css3 - 何時需要 flex-basis: 100% ?10. mysqld無法關閉
排行榜
