最近帮同事检查一个apache的问题,现象如下:
- 原本配置了多个VirtualHost,DocumentRoot指向/var/www/下不同的子目录,都能正常工作。
- 新加了一个VirtualHost,将DocumentRoot指向/home/aa/,重启apache后无法访问该VirtualHost下的内容,提示403 Forbidden,而此时访问原先的几个VirtualHost还是没有问题。
- apache错误日志里没有什么奇怪的输出。
- 操作系统CentOS 4.x。
首先考虑是不是新加的VirtualHost配置有误导致文件路径映射错误,所以用strace跟了一下apache看它在哪个阶段出问题的,发现apache去访问的文件路径在/home/aa/下,该文件也确实存在,从/home/aa/直到该文件的各级目录都有a+rx权限,apache应该能直接访问。诡异的是,apache进程调用的lstat64调用对/home、/home/aa进行权限检查时都是OK,但对/home/aa下的目标文件进行权限检查时却是EACCESS,让人百思不解。
后来才发现原来该系统上未关闭SELinux子系统,而SELinux默认会对apache进程httpd进行若干保护,其中一种就是只允许httpd访问特定路径下的文件,系统默认的/var/www在允许之列,而其他目录都是禁止访问的。解决办法:
- 临时关闭SELinux对httpd的保护:
- setsebool -P httpd_disable_trans 1
- 重启apache
- 永久关闭SELinux子系统:
- 修改/etc/sysconfig/selinux,将其中的SELINUX=...改为SELINUX=disabled
- 重启操作系统
分享到:
相关推荐
"Intel无线网卡在Linux(CentOS/RHEL)下使用" Intel无线网卡在Linux(CentOS/RHEL)下使用是一种常见的网络连接方式。为了能够在Linux系统下使用Intel WIFI,我们需要安装相应的驱动程序和配置文件。下面我们将...
Linux Polkit,也称为 PolicyKit...总之,Linux Polkit是系统权限管理的关键组件,而CVE-2021-4034的修复对于维持CentOS/RHEL 6系统的安全性至关重要。及时更新和妥善管理这些组件可以有效地保护服务器免受潜在的攻击。
3. **安全配置**: 通过修改`/etc/apache2/conf-available/security.conf`(Ubuntu/Debian)或`/etc/httpd/conf.d/security.conf`(CentOS/RHEL)来增强服务器的安全性,例如限制HTTP头部信息,禁用目录浏览等。...
一个centos7/rhel7 系统配置samba服务的教程,特别是实现windows下的share级共享
http://mirror.centos.org/centos/RPM-GPG-KEY-CentOS-7
在CentOS/RHEL 6/7系统上实现路由器功能,主要涉及以下几个关键步骤: 1. 准备工作:首先,需要准备一台安装有CentOS/RHEL 6/7系统的机器,并且该机器需要配置至少两块网卡。一块网卡用来连接内部局域网(LAN),被...
### CentOS 5.3 / RHEL 5.4 安装 Oracle 11gR2 知识点 #### 引言与背景 在2009年,Oracle发布了其备受期待的11g Release 2(R2)版本,这标志着Oracle数据库技术的一个重要里程碑。相较于之前的Release 1(R1)...
本文会告诉你怎样在 CentOS/RHEL 上设置 SSH 免密码登录。自动登录配置好以后,你可以通过它使用 SSH (Secure Shell)和安全复制 (SCP)来移动文件。 SSH 是开源的,是用于远程登录的最为可靠的网络协议。系统管理...
在本文档中,重点介绍了在CentOS7或RHEL7操作系统环境下,如何搭建基于pacemaker和corosync组件的高可用性(High Availability, HA)集群。集群技术的主要目的是通过冗余配置,确保关键服务的持续可用性和故障转移...
遇到问题时,首先查看日志文件,例如`/var/log/apache2/error.log`(Ubuntu/Debian)或`/var/log/httpd/error_log`(CentOS/RHEL)。根据错误信息,查阅官方文档或在线社区寻求解决方案。 **10. httpd-2.2与httpd-...
本文将详细讲解如何通过`yum`工具升级一个最小化安装的CentOS/RHEL系统。 首先,最小化安装的CentOS/RHEL通常只包含基本的运行系统所需的服务和工具,如网络服务、SSH和命令行工具,但缺少许多其他功能和服务。在...
shellcheck在centOS/redHat下没有可用的可执行文件或者可以直接编译生成的命令...附件是在centOS/redHat下已编译的可执行文件,理论上可以在其他centOS/redHat平台版本下使用,因编译过程太艰辛曲折,收取10分辛苦分。
Apache的日志文件通常位于`/var/log/apache2`(Ubuntu/Debian)或`/var/log/httpd`(CentOS/RHEL),通过查看这些文件可以帮助诊断和解决问题。 10. **优化性能**: 调整Apache的性能参数,如...
总之,创建一个自启动脚本并将其整合到系统服务管理中,可以方便地管理和维护Nginx服务器,确保其在CentOS/RHEL系统上稳定运行。通过遵循上述步骤,你可以有效地实现Nginx的开机自启和自动化管理。
3. 限制Apache用户访问:通过修改`/etc/apache2/envvars`(Ubuntu/Debian)或`/etc/sysconfig/httpd`(CentOS/RHEL)设置Apache运行用户和组,以提高安全性。 4. 优化性能:根据服务器硬件配置调整Apache的...
在CentOS/RHEL上,确保`php_module`在`/etc/httpd/conf.modules.d/`目录下的`.conf`文件中被加载。 最后,重启Apache服务以应用新的配置: ```bash # Ubuntu/Debian sudo systemctl restart apache2 # CentOS/...