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

解决办法有两种: 

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

  iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8080 

  将80端口映射到8080上了, 用root用户直接去执行就可以了! 

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