返回首页
DA系统
C#IDE
文件同步服务
屏保
今天是: 2026-05-05 "立夏" 夏季的第一个节气,表示盛夏时节的正式开始
收藏
任务
排行
道具
勋章
站长QQ
QQ:979119776
如您使用论坛过程中发现任何问题
请点击下方添加站长QQ
联系站长
休闲区
BBS
技术区
C#IDE
文件同步服务
喝茶淡饭
音乐区
视频区
Linux技术交流
Unity 3D、C#技术交流
Windows技术交流
论坛BUG专区
玩家杂谈
BUG专区
建议专区
搜索
搜索
热搜:
linux
技术
Hi~
登录
或
注册
本版
帖子
用户
DA 论坛
»
休闲区
›
技术区
›
Linux技术交流
›
【转载】解决普通用户不能启动nginx 80端口的问题 ...
返回列表
发新帖
查看:
2199
|
回复:
0
[转载]
【转载】解决普通用户不能启动nginx 80端口的问题
[复制链接]
da11
da11
当前离线
积分
68575
发表于 2022-4-21 15:40:33
|
显示全部楼层
|
阅读模式
少侠不来段修仙之旅吗~
您需要
登录
才可以下载或查看,没有帐号?
注册成为修仙之旅的少年~
x
解决普通用户不能启动nginx 80端口的问题
转载地址:
https://blog.csdn.net/leenhem/article/details/121910107
报错语句:nginx: [emerg] bind to 0.0.0.0:80 failed 13: Permission denied
当我们用普通用户执行启动nginx时,无法启动成功,报错
nginx: [emerg] bind() to 0.0.0.0:80 failed (13: Permission denied)
大家都知道默认情况下linux的1024以下端口是只有root用户才有权限占用,于是我们的tomcat,apache,nginx等等程序如果想要用普通用户来占用80端口的话就会抛出permission denied的异常。
方法一、依次执行如下命令
cd /usr/local/nginx/sbin/
chown root nginx
chmod u+s nginx
优点是,方便简单
缺点是,既然sudo权限都不给了,这个set uid 最后也是让nginx运行在root权限下。 ps -ef |grep nginx 查看的时候,nginx的主进程是运行在root下的。 虽然是可以让普通用户运行nginx服务,但是不是所有nginx进程都在用户本身下运行
方法二、iptables端口转发
使用非80端口启动程序,然后再用iptables做一个端口转发。
iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8080
#用root用户直接去执行就可以了!
(
sysctl -w net.ipv4.ip_forward=1
iptables -F -t nat #清空nat表
iptables -t nat -A PREROUTING -p tcp --dport 80 -j DNAT --to:8088
)
优点:可以用第三方用户直接启动,nginx的主进程就是用户本身来启动的
缺点,额外增加开销,负载低的情况可以,负载高了 就不太好了
方案三、赋予nginx监听80端口的能力
使用root执行以下命令
setcap cap_net_bind_service=+eip /home/user1/nginx/sbin/nginx
这样就可以直接用普通用户启用nginx了。并且可以在高负载的情况下,减少由于端口转发部分的负载开销。
回复
使用道具
举报
置顶卡
沉默卡
变色卡
返回列表
发新帖
游客
回复
*
滑块验证:
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
注册成为修仙之旅的少年~
发表回复
浏览过的版块
Web页面设计专区
Unity 3D、C#技术交流
Python专区
快速回复
返回顶部
返回列表