文章详情页
apache 如何记录日志
浏览:78日期: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. 主从备份 - 跪求mysql 高可用主从方案2. python - django 里自定义的 login 方法,如何使用 login_required()3. python如何不改动文件的情况下修改文件的 修改日期4. android-studio - Android 动态壁纸LayoutParams问题5. javascript - git clone 下来的项目 想在本地运行 npm run install 报错6. angular.js - 不适用其他构建工具,怎么搭建angular1项目7. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?8. mysql优化 - mysql count(id)查询速度如何优化?9. node.js - 使用 superagent 抓取 UTF-8网站乱码10. sql语句如何按or排序取出记录
排行榜
