Хадсон не запускается в tomcat5

Хадсон не запускается в tomcat5

Hudson — это механизм непрерывной интеграции, работающий как Java-сервлет в tomcat. https://hudson.dev.java.net/

У меня Tomcat 5.5 успешно установлен на моей системе CentOS 5.3. Я могу видеть его и взаимодействовать с ним на порту 8080.

Я могу загрузить файл hudson.war, который сообщает об успешном завершении и, по-видимому, правильно распаковывает все в каталог webapps.

Однако при попытке запустить приложение hudson со страницы диспетчера веб-приложений tomcat возникает ошибка «FAIL - приложение по контекстному пути /hudson не может быть запущено».

Балансировщик, администратор и другие веб-приложения по умолчанию запускаются корректно.

SELinux включен в этой системе, что в прошлом доставляло мне некоторые проблемы. Не уверен, относится ли это к данному случаю.

Лог tomcat выглядит так:

8-Jul-09 4:32:15 PM org.apache.catalina.core.ApplicationContext log
INFO: HTMLManager: start: Starting web application at '/hudson'
8-Jul-09 4:32:16 PM hudson.WebAppMain contextInitialized
SEVERE: Failed to initialize Hudson
java.lang.NoClassDefFoundError: hudson.model.Hudson
   at java.lang.Class.initializeClass(libgcj.so.7rh)
   at hudson.WebAppMain.installLogger(WebAppMain.java:227)
   at hudson.WebAppMain.contextInitialized(WebAppMain.java:112)
   at org.apache.catalina.core.StandardContext.listenerStart(catalina-5.5.23.jar.so)

   ... snip ...

   at java.lang.Class.initializeClass(libgcj.so.7rh)
   ...24 more
8-Jul-09 4:32:16 PM org.apache.catalina.core.StandardContext listenerStart
SEVERE: Exception sending context initialized event to listener instance of class hudson.WebAppMain
java.lang.NoClassDefFoundError: hudson.model.Hudson
   at java.lang.Class.initializeClass(libgcj.so.7rh)
   at hudson.WebAppMain.installLogger(WebAppMain.java:227)
   at hudson.WebAppMain.contextInitialized(WebAppMain.java:112)
   at org.apache.catalina.core.StandardContext.listenerStart(catalina-5.5.23.jar.so)

   ... snip ... 

   at org.apache.catalina.loader.WebappClassLoader.loadClass(catalina-5.5.23.jar.so)
   at java.lang.Class.forName(libgcj.so.7rh)
   at java.lang.Class.initializeClass(libgcj.so.7rh)
   ...24 more
8-Jul-09 4:32:16 PM org.apache.catalina.core.StandardContext start
SEVERE: Error listenerStart
8-Jul-09 4:32:16 PM org.apache.catalina.core.StandardContext start
SEVERE: Context [/hudson] startup failed due to previous errors
8-Jul-09 4:32:16 PM org.apache.catalina.core.StandardContext listenerStop
SEVERE: Exception sending context destroyed event to listener instance of class hudson.WebAppMain
java.lang.NoClassDefFoundError: hudson.model.Hudson
   at java.lang.Class.initializeClass(libgcj.so.7rh)
   at hudson.WebAppMain.contextDestroyed(WebAppMain.java:280)
   at org.apache.catalina.core.StandardContext.listenerStop(catalina-5.5.23.jar.so)

   ... snip ... 

   at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(tomcat-util-5.5.23.jar.so)
   at java.lang.Thread.run(libgcj.so.7rh)
8-Jul-09 4:32:16 PM org.apache.catalina.core.ApplicationContext log
INFO: HTMLManager: list: Listing contexts for virtual host 'localhost'

решение1

java.lang.NoClassDefFoundError: hudson.model.Hudson

Похоже, загрузчик классов не может загрузить классы и этомощьможет возникнуть проблема с разрешениями из-за SELinux.

Можете ли вы попробовать запустить встроенную версию Hudson, просто чтобы убедиться, что она может работать в вашей системе?

решение2

Я не смог решить это через конфигурацию, поэтому я взял урок из Aliens и сбил его с орбиты. В конце концов, это единственный способ убедиться.

Очистив версию, установленную моим менеджером пакетов (yum), я зашел на сайт tomcat и загрузил, установил и настроил их бинарный релиз Tomcat 5.5 Core и веб-приложения для администрирования.

После этого у меня возникло несколько незначительных проблем с правами доступа, я изменил скрипт, который хранится в $CATALINA_HOME/bin/jsvc-src/native/Tomcat5.sh, чтобы запустить tomcat как демон, и теперь все работает хорошо.

Знаю, это не очень удовлетворительный ответ, но я не мог позволить себе больше биться об него головой.

Связанный контент