Arhn - архитектура программирования

Ошибка выполнения задач муравья Tomcat

У меня проблема с запуском задач tomcat ant. Нашел пару похожих случаев, но ни один не помог:

ant install для развертывания веб-приложения Tomcat не удается из-за проблемы с разрешением

Почему Ant возвращает ошибку 403 при развертывании?

Ant Tomcat 7 Reload FileNotFoundException

Версии:

  • ОС: Windows 7 x64 Professional
  • Версия Java: 1.6.0_25
  • Версия Ant: 1.8.3
  • Версия Tomcat: 7.0.011

Мой tomcat-users.xml:

    <tomcat-users><role rolename="manager-script"/>
       <user username="script" password="script" roles="manager-script"/>       
       <role rolename="manager-gui"/>
       <user username="manager" password="manager!" roles="manager-gui"/>
    </tomcat-users>

Часть скрипта Ant:

<property name="app.name" value="london"/>
<property name="manager.url" value="http://localhost:8081/manager/text"/>
<property name="manager.user" value="script"/>
<property name="manager.password" value="script"/>
<property name="update.filename" value="update.war"/>   

<taskdef name="tomcatStart" classname="org.apache.catalina.ant.StartTask"/>
<taskdef name="tomcatStop" classname="org.apache.catalina.ant.StopTask"/>
<taskdef name="tomcatDeploy" classname="org.apache.catalina.ant.DeployTask"/>          

<target name="main">
<tstamp/>
<tomcatStop
    url="${manager.url}"
    username="${manager.user}"
    password="${manager.password}"
    path="/${app.name}"                    
/>

<tomcatDeploy
    url="${manager.url}"
    username="${manager.user}"
    password="${manager.password}"
    path="/${app.name}"
    war="file:${update.filename}"                                          
/>
</target>

Вывод в консоль (StopTask):

BUILD FAILED
C:\Users\username\ant\build.xml:34: java.io.FileNotFoundException:
http://localhost:8081/manager/text/stop?path=%2Flondon
at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1434)

at org.apache.catalina.ant.AbstractCatalinaTask.execute(AbstractCatalinaTask.java:228)
at org.apache.catalina.ant.AbstractCatalinaTask.execute(AbstractCatalinaTask.java:149)
at org.apache.catalina.ant.StopTask.execute(StopTask.java:73)
at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
at org.apache.tools.ant.Task.perform(Task.java:348)
at org.apache.tools.ant.Target.execute(Target.java:392)
at org.apache.tools.ant.Target.performTasks(Target.java:413)
at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
at org.apache.tools.ant.Main.runBuild(Main.java:811)
at org.apache.tools.ant.Main.startAnt(Main.java:217)
at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)

Total time: 0 seconds

Вывод консоли (DeployTask):

  BUILD FAILED
  C:\Users\username\ant\build.xml:35: java.io.IOException: Server returned HTTP response code: 403 f
  or URL: http://localhost:8081/manager/text/deploy?path=%2Flondon
  at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1436)

  at org.apache.catalina.ant.AbstractCatalinaTask.execute(AbstractCatalinaTask.java:228)
  at org.apache.catalina.ant.DeployTask.execute(DeployTask.java:211)
  at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
  at java.lang.reflect.Method.invoke(Method.java:597)
  at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
  at org.apache.tools.ant.Task.perform(Task.java:348)
  at org.apache.tools.ant.Target.execute(Target.java:392)
  at org.apache.tools.ant.Target.performTasks(Target.java:413)
  at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
  at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
  at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
  at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
  at org.apache.tools.ant.Main.runBuild(Main.java:811)
  at org.apache.tools.ant.Main.startAnt(Main.java:217)
  at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
  at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)

  Total time: 0 seconds

Странно то, что у меня это сработало пару раз, но теперь это снова не работает.

Еще одна странность заключается в том, что
StartTask и StopTask генерируют FileNotFoundException, а
DeployTask генерирует java.io.IOException: Сервер вернул код HTTP-ответа: 403...

Возможно ли, что ошибка вызвана закодированным (%2F) символом косой черты в пути?

Большое спасибо)

13.03.2012

  • это может быть глупый вопрос, но уверены ли вы, что localhost:8081/manager/text указывает на сервлет менеджера? Разве это не просто localhost:8081/manager? 14.03.2012
  • Да, для задач Ant URL-адрес должен быть /manager/text. /manager/ используется для доступа к графическому интерфейсу. 15.03.2012

Ответы:


1

Вроде все настройки в порядке:

  • Я удалил папку Tomcat
  • распаковал новую копию
  • примененные настройки

и все работает сейчас.

Плохо не проверить это раньше.

15.03.2012
Новые материалы

Коллекции публикаций по глубокому обучению
Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

Представляем: Pepita
Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

Советы по коду Laravel #2
1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

3 способа решить квадратное уравнение (3-й мой любимый) -
1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

Создание VR-миров с A-Frame
Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

Демистификация рекурсии
КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..