nginx报Permission denied

今天测nginx做反向代理,发现报错:

connect() to xxx.xxx.xx.x:xxxx failed (13: Permission denied) while
connecting to upstream

一开始以为是nginx运行用户权限的原因,修改为root之后也没用,发现这是请求后台地址报的权限不足。找了一圈发现是selinux的原因,于是尝试把selinux关了:

setenforce 0

selinux由enforcing状态变成permissive。惊喜发现可以了,后来想了一下,关闭也不安全,于是又找了一下,可以把httpd连接网络打开:

setsebool -P httpd_can_network_connect 1
#httpd可以连接到网络(如连接redis就必须设置)

事先用getsebool httpd_can_network_connect查看是关闭状态,此时nginx还是报权限不足,打开后就可以了!

后来我尝试绑定其他端口,如8888,结果报bind xxx.xxx.xxx.xxx:8888失败,也是Permission denied的报错,这次是直接启动不了了。然后关闭setlinux就可以了,原因是selinux限制了一些非常用端口的访问。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值