场景
使用nginx
直接启动成功,使用systemctl
启动nginx
服务时报错
nginx: [emerg] bind() to 0.0.0.0:19993 failed (13: Permission denied)
原因
SELinux
安全增强模块导致的
排查方法
- 执行以下命令暂时禁用
sudo setenforce 0
- 再次执行
systemctl
启动nginx
,如能启动成功则证明是当前原因
解决方法
- 查看端口规则是否有nginx中配置的端口
sudo semanage port -l | grep http_port_t
如果提示找不到命令,则需要安装工具包
sudo yum install policycoreutils-python-utils # CentOS/RHEL sudo apt-get install policycoreutils-python-utils # Ubuntu/Debian
如果报错自行搜索原因
- 添加配置端口
semanage port -a -t http_port_t -p tcp 19993
- 打开
SELinux
sudo setenforce 1
- 使用
systemctl
重启nginx
试验
其他可能的原因
- 端口占用
- 用户权限低