nginx: [emerg] bind() to 0.0.0.0:9090 failed (13: Permission denied)

systemctl start nginx.service        启动失败

systemctl status nginx.service


问题:8月 10 16:03:54 localhost.localdomain nginx[11382]: nginx: [emerg] bind() to 0.0.0.0:9090 failed (13: Permission denied)
解决:
# This will most likely be related to SELinux
semanage port -l | grep http_port_t
http_port_t                    tcp      80, 81, 443, 488, 8008, 8009, 8443, 9000


#As you can see from the output above with SELinux in enforcing mode http is only allowed to bind to the listed ports. The solution is to add the ports you want to bind on to the list

[root@localhost html]# semanage port -a -t http_port_t -p tcp 9090        # add
[root@localhost html]# semanage port -d -t http_port_t -p tcp 9090        # del
[root@localhost html]# semanage port -m -t http_port_t -p tcp 9090        # 若想添加其他已定义端口,可使用 -m 修改命令

semanage port -a -t http_port_t  -p tcp 9090                     #will add port 9090 to the list.
setsebool -P named_tcp_bind_http_port 1


https://my.oschina.net/aibati2008/blog/729674

https://serverfault.com/questions/566317/nginx-no-permission-to-bind-port-8090-but-it-binds-to-80-and-8080
posted @   张同光  阅读(560)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示