SELINUX阻止NGINX服务访问,超详细解决方法!!!

一、问题描述与原因分析

yum 安装 nginx 服务,配置好nginx进行web访问页面报错如下:

在这里插入图片描述

查看nginx日志报错:
[root@host-10-18-85-186 ~]# tail -100f /var/log/nginx/error.log #查看日志命令

在这里插入图片描述

再次查看 audit.log 以下错误信息
[root@host-10-18-85-186 ~]# cat /var/log/audit/audit.log #查看日志命令

在这里插入图片描述

原因分析:经确认是linux系统默认下SELinux处于打开状态,限制了nginx服务的访问。SELinux 是基于最小权限原则默认拦截了 Nginx 的请求,SELinux 是 Linux的安全子系统,提供更安全的访问控制,许多运维人员嫌麻烦可能会直接关闭此组件,但是治标不治本。本文提供了关闭SELinux组件和在启用 SELinux 基础上放行Nginx 请求的两种方法。

二、解决方法

1、确认 SELinux 运行状态

[root@host-10-18-85-186 ~]# sestatus
SELinux status:                 enabled
SELinuxfs mount:                /sys/fs/selinux
SELinux root directory:         /etc/selinux
Loaded policy name:             targeted
Current mode:                   enforcing
Mode from config file:          enforcing
Policy MLS status:              enabled
Policy deny_unknown status:     allowed
Max kernel policy version:      31

注:SELinux status为 enabled表示 SELinux开启,使用"/usr/sbin/sestatus -v"或"getenforce"都可查看,可使用下面命令进行关闭

# 临时关闭(临时启动命令: SELinux:setenforce 1)
SELinux:setenforce 0  
 
#永久关闭(需重启系统)
vi /etc/sysconfig/selinux
SELINUX=enforcing 改为 SELINUX=disabled
注:sed -i 's/^ *SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config 命令可迅速关闭

注意:如果在启用SELinux 组件的情况下允许nginx服务访问,需进行下面2、3、4步骤

2、开启 HTTP 访问。

[root@host-10-18-85-186 ~]# cd  /var/log/audit/
[root@host-10-18-85-186 audit]# setsebool -P httpd_can_network_connect 1

3、分析现有日志并生成关联模块,执行完此命令可以看到在当前目录下会生成后缀为*.pp和*.te文件,如果该服务器上的服务未被访问过,此命令执行无效。

[root@host-10-18-85-186 audit]# ausearch -c 'nginx' --raw | audit2allow -M my-nginx

4、加载前一步生成的模块内容

[root@host-10-18-85-186 audit]# semodule -i my-nginx.pp

完成上述操作nginx可正常访问!!!

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果在 CentOS 7 上使用 Nginx 作为 Web 服务器,并且在访问 PHP 页面时出现空白页面,可能是 PHP-FPM 没有正常工作的原因。您可以按照以下步骤解决该问题: 1. 检查 PHP-FPM 是否正在运行。 ``` systemctl status php-fpm ``` 如果没有运行,请使用以下命令启动 PHP-FPM: ``` systemctl start php-fpm ``` 2. 检查 Nginx 配置文件中的 PHP-FPM 配置是否正确。 在 Nginx 配置文件中,通常会有类似以下的配置: ``` location ~ \.php$ { fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } ``` 请确保 fastcgi_pass 指向正确的 PHP-FPM socket 文件路径,例如 /var/run/php-fpm/php-fpm.sock。 3. 检查 Nginx 和 PHP-FPM 用户组是否匹配。 在 CentOS 7 上,默认情况下,Nginx 运行在 nginx 用户组中,而 PHP-FPM 运行在 apache 用户组中。您可以使用以下命令查看它们的用户组: ``` ps aux | grep nginx ps aux | grep php-fpm ``` 请确保这两个进程都运行在相同的用户组中,例如 nginx。 4. 检查 SELinux 配置是否正确。 SELinux 是 CentOS 7 默认启用的强制访问控制机制。如果配置不正确,可能会阻止 Nginx 访问 PHP-FPM。您可以使用以下命令检查 SELinux 配置: ``` sestatus ``` 如果 SELinux 处于 enforcing 模式,请确保以下命令将 Nginx 和 PHP-FPM 标记为 httpd_sys_script_exec_t 类型: ``` semanage fcontext -a -t httpd_sys_script_exec_t '/usr/share/nginx/html(/.*)?' restorecon -R /usr/share/nginx/html ``` 这些步骤应该可以解决您的问题。如果问题仍然存在,请检查 Nginx 和 PHP-FPM 的日志文件以获取更多信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值