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

默认情况下Linux的1024以下端口是只有root用户才有权限占用,我们的tomcat,apache,nginx等等程序如果想要用普通用户来占用80端口的话就会抛出java.net.BindException:Permissiondenied:80的异常。

解决办法有两种:

1.使用非80端口启动程序,然后再用iptables做一个端口转发。

iptables-tnat-APREROUTING-ptcp--dport80-jREDIRECT--to-port8080

用root用户直接去执行就可以了!

2.假设我们需要启动的程序是nginx,那么这么做也可以达到目的。

一开始我们查看nginx的权限描述:

-rwxr-xr-x1nginxdev2408122Sep516:01nginx

这个时候必然是无法正常启动的。

首先修改文件所属用户为root:

chownrootnginx

然后再加上s权限:

chmodu+snginx

再次查看权限描述的时候:

-rwsr-xr-x1rootroot2408122Sep516:01nginx

这样就能启动了。

相关推荐