普通用户启动nginx并监听80端口

转自:http://www.codexiu.cn/nginx/blog/26217/



众所周知,linux 0-1024 端口是不允许非root权限用户占用的。

但是在linux中,因为安全问题,root用户禁止登陆服务器,而且又不给普通用户 sudo权限 

这种情况下 nginx既要可以用普通用户启用,还要占用80端口

首先用普通用户 编辑安装nginx

目前我有三种解决方案:

方案一 SetUID    

chmod u+s /usr/local/nginx/sbin/nginx

其实就是赋予这个nignx二进制文件,能够像在root下运行

优点是,方便简单,缺点是,既然sudo权限都不给了。这个set uid 最后也是让nginx运行在root权限下。 ps -ef |grep nginx 查看的时候,nginx的主进程是运行在root下的。 虽然是可以让普通用户运行nginx服务,但是不是所有nginx进程都在用户本身下运行

方案二:端口转发

因为0-1024 的端口不能被非root用户占用 ,我们可以把监听端口修改成1024以上的端口,然后用iptables进行端口转发,把80端口的包转发到 1024以上 我们自定义的端口

首先 打开 转发功能

sysctl -w net.ipv4.ip_forward=1

  1. iptables -F -t nat   #清空nat表

  2. iptables -t nat -A PREROUTING -p tcp --dport 80 -j DNAT --to:8088  #nat表PREROUTING 链中插入转发规则

优点:可以用第三方用户直接启动,nginx的主进程就是用户本身来启动的。缺点,额外增加开销,负载低的情况可以,负载高了 就不太好了

方案三:

nginx内核 超过2.1版本以后 出现了能力的说法,

我们可以给/usr/local/nginx/sbin/nginx 赋予监听80端口的权限能力,

  1. setcap cap_net_bind_service =+ep /usr/local/nginx/sbin/nginx

这样就可以直接用普通用户启用nginx了。并且可以在高负载的情况下,减少由于端口转发部分的负载开销。


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
nginx中,监听80端口并进行转发是可以实现的。你可以通过配置nginx的反向代理来实现这个功能。首先,在nginx的配置文件中,你可以定义一个server块来监听80端口,并在location中设置proxy_pass指令来指定转发的目标地址。比如:server { listen 80; server_name localhost; location / { proxy_pass http://x.x.x.x:9500; proxy_set_header Host $host:80; proxy_set_header X-Real-... } 然后,你需要保存并生效这个配置。可以使用nginx -s reload命令来重载配置文件,或者使用service nginx restart命令来重启nginx服务。这样,nginx就会监听80端口并将请求转发到指定的目标地址了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Nginx服务器中配置非80端口端口转发方法详解](https://download.csdn.net/download/weixin_38655496/14092017)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [nginx监听80端口转发到tomcat 8080端口](https://blog.csdn.net/weixin_48251552/article/details/126824318)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值