Я следил за этим http://www.mogilowski.net/lang/en-us/2014/04/22/install-apache-tomcat-8-on-debian-7-wheezy-with-virtual-hosts-and-apache2-integration/ для установки tomcat на VPS, версия 8.0.20 ...
Я пытаюсь изменить порт на 80, но нет возможности сделать это, я пробовал:
http://beginlinux.com/server/ubuntu/changing-the-port-on-tomcat
но, похоже, не работает, получая эту ошибку от catalina.out внутри журналов:
25-Feb-2015 01:32:23.879 SEVERE [main] org.apache.catalina.core.StandardService.initInternal Failed to initialize connector [Connector[HTTP/1.1-$
org.apache.catalina.LifecycleException: Failed to initialize component [Connector[HTTP/1.1-80]]
at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:106)
at org.apache.catalina.core.StandardService.initInternal(StandardService.java:567)
at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:102)
at org.apache.catalina.core.StandardServer.initInternal(StandardServer.java:851)
at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:102)
at org.apache.catalina.startup.Catalina.load(Catalina.java:576)
at org.apache.catalina.startup.Catalina.load(Catalina.java:599)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.apache.catalina.startup.Bootstrap.load(Bootstrap.java:310)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:484)
Caused by: org.apache.catalina.LifecycleException: Protocol handler initialization failed
at org.apache.catalina.connector.Connector.initInternal(Connector.java:962)
at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:102)
... 12 more
Caused by: java.net.SocketException: Permission denied
at sun.nio.ch.Net.bind0(Native Method)
at sun.nio.ch.Net.bind(Net.java:444)
at sun.nio.ch.Net.bind(Net.java:436)
at sun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:214)
at sun.nio.ch.ServerSocketAdaptor.bind(ServerSocketAdaptor.java:74)
at org.apache.tomcat.util.net.NioEndpoint.bind(NioEndpoint.java:343)
at org.apache.tomcat.util.net.AbstractEndpoint.init(AbstractEndpoint.java:732)
at org.apache.coyote.AbstractProtocol.init(AbstractProtocol.java:457)
at org.apache.coyote.http11.AbstractHttp11JsseProtocol.init(AbstractHttp11JsseProtocol.java:120)
at org.apache.catalina.connector.Connector.initInternal(Connector.java:960)
... 13 more
Это мой порт разъема, что с ним?
<Connector port="80" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="443" />
Вам нужно будет запустить Tomcat с правами root, чтобы он мог привязаться к порту 80. Для привязки всех портов ниже 1024 требуются права суперпользователя.
Это также то, что пытается сказать вам последнее исключение в stacktrace:
Caused by: java.net.SocketException: Permission denied
at sun.nio.ch.Net.bind0(Native Method)
at sun.nio.ch.Net.bind(Net.java:444)
at sun.nio.ch.Net.bind(Net.java:436)
at sun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:214)
at sun.nio.ch.ServerSocketAdaptor.bind(ServerSocketAdaptor.java:74)
at org.apache.tomcat.util.net.NioEndpoint.bind(NioEndpoint.java:343)
at org.apache.tomcat.util.net.AbstractEndpoint.init(AbstractEndpoint.java:732)
at org.apache.coyote.AbstractProtocol.init(AbstractProtocol.java:457)
at org.apache.coyote.http11.AbstractHttp11JsseProtocol.init(AbstractHttp11JsseProtocol.java:120)
at org.apache.catalina.connector.Connector.initInternal(Connector.java:960)
... 13 more
Очень короткое предупреждение, не превращая это в расширенное обсуждение безопасности: с точки зрения безопасности, как правило, не рекомендуется запускать Tomcat (или, возможно, любое приложение Java) с разрешениями суперпользователя. Ошибки в веб-приложении, размещенном на Tomcat, могут привести к выполнению произвольного кода с этими разрешениями, что может дать удаленному злоумышленнику root-доступ к системе.
По этой причине (среди прочего) порт Tomcat по умолчанию - непривилегированный 8080. Для привязки не требуется прав суперпользователя, поэтому Tomcat можно запускать как обычный системный пользователь.
Если вам действительно нужно получить доступ к веб-приложению, размещенному на Tomcat, через порт 80, вы должны подключить экземпляр Tomcat к веб-серверу, например Apache. Он прослушивает порт 80 и выполняет обратный прокси-сервер в Tomcat. Это более безопасно, не в последнюю очередь потому, что Apache теряет свои привилегии суперпользователя после привязки к порту 80.
Конфигурация виртуального хоста Apache, которая делает это, может выглядеть так:
<VirtualHost *:80>
ServerAdmin webmaster
ServerName foo.example.com
ProxyPreserveHost on
ProxyRequests off
ProxyPass / http://localhost:8080/
ProxyPassReverse / http://localhost:8080/
</VirtualHost>