非root启动80端口

Posted bethal

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了非root启动80端口相关的知识,希望对你有一定的参考价值。

Linux非root用户如何使用80端口启动程序

 
默认情况下Linux的1024以下端口是只有root用户才有权限占用,我们的tomcat,apache,nginx等等程序如果想要用普通用户来占用80端口的话就会抛出java.net.BindException: Permission denied:80的异常。 
  www.2cto.com  
解决办法有两种: 
 
1.使用非80端口启动程序,然后再用iptables做一个端口转发。 
 
  iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8080 
 
  用root用户直接去执行就可以了! 
 
2.假设我们需要启动的程序是nginx,那么这么做也可以达到目的。 
 
一开始我们查看nginx的权限描述:   www.2cto.com  
 
-rwxr-xr-x 1 nginx dev 2408122 Sep  5 16:01 nginx 
 
这个时候必然是无法正常启动的。 
 
首先修改文件所属用户为root: 
 
chown root nginx 
 
然后再加上s权限: 
 
chmod u+s nginx 
 
再次查看权限描述的时候: 
 
-rwsr-xr-x 1 root root 2408122 Sep  5 16:01 nginx 
 
这样就能启动了。 
 

以上是关于非root启动80端口的主要内容,如果未能解决你的问题,请参考以下文章

如何在普通用户下,使用nginx启动80端口

配置iptables,把80端口转到8080

配置iptables,把80端口转到8080

Linux 普通用户启动nginx

在 80 端口启动 webrick(mysql2 gem 问题)

Mac OS X 绑定80端口,不装nginx的小技巧