горячее развертывание простого применения в пристани - PullRequest
1 голос
/ 04 марта 2010

Я работаю с Jetty Hightide Vesion 7 в настоящее время как отдельный сервер. У меня есть простой веб-проект с парой jsp и вспомогательных классов, которые я сейчас развертываю в неразорвавшейся войне в каталог JETTY_HOME / webapps.

В настоящее время Jetty легко обнаруживает любые статические изменения jsp / html. Если я правильно понимаю, я могу настроить свое приложение так, чтобы Jetty принимал любые изменения класса без перезапуска сервера? В настоящее время у меня есть в моем jetty-web.xml:

<?xml version="1.0"  encoding="ISO-8859-1"?>
<!DOCTYPE Configure PUBLIC "-//Mort Bay Consulting//DTD Configure//EN" "http://www.eclipse.org/jetty/configure.dtd">

<!--
    This is the jetty specific web application configuration file. When
    starting a Web Application, the WEB-INF/web-jetty.xml file is looked
    for and if found, treated as a
    org.eclipse.jetty.server.server.xml.XmlConfiguration file and is
    applied to the org.eclipse.jetty.servlet.WebApplicationContext objet
-->

<Configure class="org.eclipse.jetty.webapp.WebAppContext">
<Call class="org.eclipse.jetty.util.log.Log" name="debug">
    <Arg>executing jetty-web.xml</Arg>
</Call>
<Set name="contextPath">/SimpleDynamicProject</Set>

</Configure>

Я также создал SimpleDynamicProject.xml и поместил его в JETTY_HOME / contexts. Этот файл содержит:

<?xml version="1.0"  encoding="ISO-8859-1"?>
<!DOCTYPE Configure PUBLIC "-//Mort Bay Consulting//DTD Configure//EN" "http://www.eclipse.org/jetty/configure.dtd">

<!--
    This is the jetty specific web application configuration file. When
    starting a Web Application, the WEB-INF/web-jetty.xml file is looked
    for and if found, treated as a
    org.eclipse.jetty.server.server.xml.XmlConfiguration file and is
    applied to the org.eclipse.jetty.servlet.WebApplicationContext objet
-->

<Configure class="org.eclipse.jetty.webapp.WebAppContext">

<Set name="contextPath">/SimpleDynamicProject</Set>
<Set name="resourceBase"><SystemProperty name="jetty.home" default="."/>/webapps/SimpleDynamicProject</Set>
</Configure>

Я также не уверен, как правильно запустить Jetty в режиме отладки, который я прочитал, также было необходимо. Я попытался запустить сервер с:

java -Xdebug -jar start.jar OPTIONS=Server,jsp

и

java -Ddebug -jar start.jar OPTIONS=Server,jsp

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

Спасибо за помощь.

Ответы [ 2 ]

5 голосов
/ 05 марта 2010

Вам необходимо определить ContextDeployer с ненулевым интервалом сканирования:

<Call name="addLifeCycle">
  <Arg>
    <New class="org.mortbay.jetty.deployer.ContextDeployer">
      <Set name="contexts"><Ref id="Contexts"/></Set>
      <Set name="configurationDir"><SystemProperty name="jetty.home" default="."/>/contexts</Set>
      <Set name="scanInterval">1</Set>
    </New>
  </Arg>
</Call>

Что касается отладки, я предполагаю, что вы имеете в виду подключение удаленного отладчика с использованием JPDA. Для этого вам нужно установить параметр -agentlib:jdwp 1 :

-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005

Настройка отладчика IDE для подключения через указанный порт.

1 если целевая виртуальная машина 5.0 или новее, -agentlib:jdwp предпочтительнее, чем опции -Xdebug и -Xrunjdwp, которые все еще поддерживаются.

0 голосов
/ 29 августа 2010

Если вы хотите использовать плагин Jetty Maven

   <plugin>
        <groupId>org.mortbay.jetty</groupId>
        <artifactId>maven-jetty-plugin</artifactId>
        <version>6.1.25</version>
        <configuration>
            <scanIntervalSeconds>10</scanIntervalSeconds>
            <requestLog implementation="org.mortbay.jetty.NCSARequestLog">
                <!--
                          This doesn't do anything for Jetty, but is a workaround for a
                          Maven bug that prevents the requestLog from being set.
                      -->
                <append>true</append>
            </requestLog>
            <webApp>${basedir}/out/war/Spring2_5_6_war.war</webApp>
        </configuration>
    </plugin>
...