Jetty не может найти файл веб-приложения
Я установил причал, используя PKGBUILD
от AUR. Конфигурация была оставлена по умолчанию.
Примечание: с makepkg
не удалось загрузить Jetty v.9.3.2 с официального сайта, я загрузил его из репозитория Maven
Проблема заключается в том, что когда я пытаюсь развернуть свое веб-приложение с помощью XML-файла Jetty Deployable Descriptor, Jetty не может найти войну со следующим исключением:
2016-01-27 17:05:30.265:WARN:oejw.WebInfConfiguration:main: Web application not found /home/pmitrofanov/sample.war
2016-01-27 17:05:30.265:WARN:oejw.WebAppContext:main: Failed startup of context o.e.j.w.WebAppContext@1efbd816{/sample,null,null}{/home/pmitrofanov/sample.war}
java.io.FileNotFoundException: /home/pmitrofanov/sample.war
at org.eclipse.jetty.webapp.WebInfConfiguration.unpack(WebInfConfiguration.java:495)
at org.eclipse.jetty.webapp.WebInfConfiguration.preConfigure(WebInfConfiguration.java:72)
at org.eclipse.jetty.webapp.WebAppContext.preConfigure(WebAppContext.java:474)
at org.eclipse.jetty.webapp.WebAppContext.doStart(WebAppContext.java:510)
at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68)
at org.eclipse.jetty.deploy.bindings.StandardStarter.processBinding(StandardStarter.java:41)
at org.eclipse.jetty.deploy.AppLifeCycle.runBindings(AppLifeCycle.java:188)
at org.eclipse.jetty.deploy.DeploymentManager.requestAppGoal(DeploymentManager.java:499)
at org.eclipse.jetty.deploy.DeploymentManager.addApp(DeploymentManager.java:147)
at org.eclipse.jetty.deploy.providers.ScanningAppProvider.fileAdded(ScanningAppProvider.java:180)
at org.eclipse.jetty.deploy.providers.WebAppProvider.fileAdded(WebAppProvider.java:459)
at org.eclipse.jetty.deploy.providers.ScanningAppProvider$1.fileAdded(ScanningAppProvider.java:64)
at org.eclipse.jetty.util.Scanner.reportAddition(Scanner.java:610)
at org.eclipse.jetty.util.Scanner.reportDifferences(Scanner.java:529)
at org.eclipse.jetty.util.Scanner.scan(Scanner.java:392)
at org.eclipse.jetty.util.Scanner.doStart(Scanner.java:313)
at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68)
at org.eclipse.jetty.deploy.providers.ScanningAppProvider.doStart(ScanningAppProvider.java:150)
at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68)
at org.eclipse.jetty.deploy.DeploymentManager.startAppProvider(DeploymentManager.java:561)
at org.eclipse.jetty.deploy.DeploymentManager.doStart(DeploymentManager.java:236)
at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68)
at org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:132)
at org.eclipse.jetty.server.Server.start(Server.java:405)
at org.eclipse.jetty.util.component.ContainerLifeCycle.doStart(ContainerLifeCycle.java:114)
at org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHandler.java:61)
at org.eclipse.jetty.server.Server.doStart(Server.java:372)
at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68)
at org.eclipse.jetty.xml.XmlConfiguration$1.run(XmlConfiguration.java:1510)
at java.security.AccessController.doPrivileged(Native Method)
at org.eclipse.jetty.xml.XmlConfiguration.main(XmlConfiguration.java:1435)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.eclipse.jetty.start.Main.invokeMain(Main.java:214)
at org.eclipse.jetty.start.Main.start(Main.java:457)
at org.eclipse.jetty.start.Main.main(Main.java:75)
Вот содержимое XML:
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE Configure PUBLIC "-//Jetty//Configure//EN" "http://www.eclipse.org/jetty/configure.dtd">
<Configure class="org.eclipse.jetty.webapp.WebAppContext">
<Set name="contextPath">/sample</Set>
<Set name="war">/home/pmitrofanov/sample.war</Set>
<!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
<!-- Max Form Size -->
<!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
<Set name="maxFormContentSize">5000000</Set>
</Configure>
Следует отметить, что:
- Когда я вручную помещаю войну в каталог webapps вместо использования xml, все идет хорошо.
- Все пользователи имеют доступ к войне rwx:
-rwxrwxrwx 1 pmitrofanov pmitrofanov 25104375 Jan 27 16:37 /home/pmitrofanov/sample.war
2 ответа
Решение
Проблема в том, что никто кроме владельца не имеет права на чтение + выполнение /home/pmitrofanov
каталог.
Несколько вещей, на которые стоит обратить внимание...
- Формат и синтаксис Jetty XML изменился для Jetty 9.3, он имеет новый DTD (настоятельно рекомендуется использовать его)
- Jetty 8 - EOL (Конец Жизни)
- Начиная с Servlet 3.x, если вы выполняете загрузку файлов через POST, лучше использовать
@MultipartConfig
или же<multipart-config>
определить местоположение, размеры, пределы и т. д. (неWebAppContext
настройки) - Начиная с Jetty 9, если вы работаете с большими заголовками запросов (на что указывает ваш максимальный размер содержимого в 5 000 000 байт), вам, вероятно, нужно знать о соединителе.
HttpConfiguration
что ограничивает размеры заголовка запроса более строго, чем вашWebAppContext
Настройки. - В вашем примере
${jetty.base}/webapps/sample.xml
при запуске он сразу же ищет файл войны, если не может найти его, он не будет развернут. (вы используете${jetty.base}
с Jetty 9, верно? вам никогда не следует изменять / добавлять / удалять файлы в дистрибутиве Jetty) - Простая замена войны НЕ приведет к повторному развертыванию файла войны. Вам придется прикоснуться к
${jetty.base}/webappps/sample.xml
вызвать повторное развертывание. - Не предусмотрено положение о мониторинге ресурсов, на которые есть ссылки в XML, только содержание в
${jetty.base}/webapps/