• 转 maven jetty 插件


    本机环境

    JDK 7 Maven 3.2 Jetty 9.2 Eclipse Luna

    pom.xml 配置

    在你的 pom.xml 文件中添加 jetty 插件的描述信息(查看Jetty更多的版本信息):
    [...]
    <build>
      <plugins>
        <plugin>
          <groupId>org.eclipse.jetty</groupId>
          <artifactId>jetty-maven-plugin</artifactId>
          <version>9.2.8.v20150217</version>
        </plugin>
      </plugins>
    </build>
    [...]

    启动 & 停止

    命令行方式启动 jetty mvn jetty:run,可以通过 Ctrl + C 停止 jetty 服务。
    或者,在 eclipse 中选中项目 --> 右键 --> Run As --> Maven build...,在 Goals 栏输入 jetty:run(与命令行方式相比,仅仅是
    少了 mvn 前缀,为方便起见,以下均以命令行方式介绍。) 

    jetty 9 部署的项目的 Context path 默认是 /,也就是说,项目的访问入口地址是:http://localhost:8080(不带项目名)
    如果你希望通过命令 mvn jetty:stop 执行关闭 jetty 服务,你需要像下面一样在你的 pom.xml 配置文件中添加一个特殊的端口和控制键: 
    <configuration>
      [...]
      <stopKey>shutdown</stopKey>
      <stopPort>9966</stopPort>
      [...]
    </configuration>
    你仍可以通过 mvn jetty:run 启动 jetty 服务,可以通过 mvn jetty:stop 来停止 jetty 服务。

    取消文件映射缓存

    jetty 默认开启了 useFileMappedBuffer,在 jetty 运行期间,页面所使用的静态文件(如 css 文件等)不允许修改。如果你尝试去修改它
    们,保存的时候就会出现 Save could not be completed. 

    解决办法,找到 %repo%/org/eclipse/jetty/jetty-webapp/9.2.8.v20150217/jetty-webapp-9.2.8.v20150217.jar(%repo% 表示你
    本地的 maven 仓库的目录,另外,将 9.2.8.v20150217 换成你所使用的版本)。用压缩工具打开它, 找到 jetty-webapp-9.2.8.v2015021
    7.jar/org/eclipse/jetty/webapp/webdefault.xml,将 webdefault.xml 文件解压缩一份出来,用文本编辑器打开它,搜索找到
    useFileMappedBuffer 配置的行,将 true 改成 false 以禁掉缓存。
    <init-param>
      <param-name>useFileMappedBuffer</param-name>
      <param-value>false</param-value>
    </init-param>
    先确认 jetty 服务已经停止,将原文件 jetty-webapp-9.2.8.v20150217.jar/org/eclipse/jetty/webapp/webdefault.xml 删除,将刚
    才那份修改好的 webdefault.xml 文件重新压缩进去即可。

    端口配置

    jetty 默认使用的端口是 8080,命令行的方式修改端口的命令是:mvn -Djetty.port=8081 jetty:run 。pom.xml 配置方式如下: 
    <configuration>
      [...]
      <httpConnector>
        <port>8081</port>
      </httpConnector>
      [...]
    </configuration>

    自动热部署

    在你的 pom.xml 中添加如下配置: 
    <configuration>
      [...]
      <scanIntervalSeconds>2</scanIntervalSeconds>
      [...]
    </configuration>
    默认值是 0。大于 0 的数值表示开启,0 表示关闭,单位为秒。以配置数值为一个周期,自动的扫描文件检查其内容是否有变化,如果发现文件的
    内容被改变,则自动重新部署运用。命令行的方式:mvn -Djetty.scanIntervalSeconds=2 jetty:run 。

    手动重加载

    在你的 pom.xml 文件中添加如下配置,reload 的可选值 :[automatic|manual]
    <configuration>
      [...]
      <reload>manual</reload>
      [...]
    </configuration>
    默认值为 automatic,它与大于 0 的 scanIntervalSeconds 节点一起作用,实现自动热部署的工作。设为 manual 的好处是,当你改变文件
    内容并保存时,不会马上触发自动扫描和重部署的动作,你还可以继续的修改,直至你在 Console 或命令行中敲回车键(Enter)的时候才触发重
    新加载的动作。这样可以更加的方便调试修改。命令行的方式是:mvn -Djetty.reload=manual jetty:run 。

    访问日志

    在你的 pom.xml 文件添加如下配置: 
    <configuration>
      [...]
      <requestLog implementation="org.eclipse.jetty.server.NCSARequestLog">
        <filename>target/access-yyyy_mm_dd.log</filename>
        <filenameDateFormat>yyyy_MM_dd</filenameDateFormat>
        <logDateFormat>yyyy-MM-dd HH:mm:ss</logDateFormat>
        <logTimeZone>GMT+8:00</logTimeZone>
        <append>true</append>
        <logServer>true</logServer>
        <retainDays>120</retainDays>
        <logCookies>true</logCookies>
      </requestLog>
      [...]
    </configuration>
    org.eclipse.jetty.server.NCSARequestLog 是 org.eclipse.jetty.server.RequestLog 的一个实现类。
    org.eclipse.jetty.server.NCSARequestLog 是一种伪标准的 NCSA 日志格式。下面是一些节点参数的解释:
    filename:日志文件的名称
    filenameDateFormat:日志文件的名称的日期格式,它要求日志文件名必须含有 yyyy_mm_dd 串
    logDateFormat:日志内容的时间格式
    logTimeZone:时区
    append:追加到日志
    logServer:记录访问的主机名
    retainDays:日志文件保存的天数, 超过删除
    logCookies:记录 cookies
    启动 jetty 服务,在项目的 target 目录下会生成一个 access-2015_06_23.log 文件,该文件中的其中一条记录如下:
    localhost 0:0:0:0:0:0:0:1 - - [2015-06-23 01:17:05] "GET /css/main.css HTTP/1.1" 304 - 
    "http://localhost:8081/"  "Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) 
    Chrome/35.0.1916.153 Safari/537.36 SE 2.X MetaSr 1.0" "JSESSIONID=2gyikovul2iz168116l2afo4f"

    转储快照

    在你的 pom.xml 文件添加如下配置: 
    <configuration>
      [...]
      <dumpOnStart>true</dumpOnStart>
      [...]
    </configuration>
    dumpOnStart 默认值为 false,如果设为 true,jetty 在启动时会把当前服务进程的内存信息输出到控制台中,但这并不会保存到文件中。

    WEB上下文

    最常用的是 contextPath,它的配置如下: 
    <configuration>
      [...]
      <webApp>
        <contextPath>/${project.artifactId}</contextPath>
      </webApp>
      [...]
    </configuration>
    contextPath 的默认值的 /,${project.artifactId} 引用了 <artifactId> 节点的值,即项目的名称。
    项目的静态资源文件目录默认是 src/main/webapp,如果静态资源目录有多个,或者不在默认的 src/main/webapp 目录下,可做如下配置: 
    <configuration>
      [...]
      <webApp>
        <contextPath>/${project.artifactId}</contextPath>
        <resourceBases>
          <resourceBase>${project.basedir}/src/main/webapp</resourceBase>
          <resourceBase>${project.basedir}/commons</resourceBase>
        </resourceBases>
      </webApp>
      [...]
    </configuration>
    引用静态资源文件时,路径不包含资源目录的名称,如 commons/main.css,引用方式为:<link href="main.css" rel="stylesheet" /> 
    更多参数信息可参考 jetty-maven-plugin.html#configuring-your-webapp

    完整的配置

    附 pom.xml 文件中 jetty 插件的完整配置片段: 
    <build>
      [...]
      <plugins>
        <plugin>
          <groupId>org.eclipse.jetty</groupId>
          <artifactId>jetty-maven-plugin</artifactId>
          <version>9.2.8.v20150217</version>
          <configuration>
            <httpConnector>
              <port>8081</port>
            </httpConnector>
            <stopKey>shutdown</stopKey>
            <stopPort>9966</stopPort>
            <!--
            <scanIntervalSeconds>2</scanIntervalSeconds>
            -->
            <reload>manual</reload>
            <dumpOnStart>true</dumpOnStart>
            <webApp>
              <contextPath>/${project.artifactId}</contextPath>
              <!--
              <resourceBases>
                <resourceBase>${project.basedir}/src/main/webapp</resourceBase>
                <resourceBase>${project.basedir}/commons</resourceBase>
              </resourceBases>
              -->
            </webApp>
            <requestLog implementation="org.eclipse.jetty.server.NCSARequestLog">
              <filename>target/access-yyyy_mm_dd.log</filename>
              <filenameDateFormat>yyyy_MM_dd</filenameDateFormat>
              <logDateFormat>yyyy-MM-dd HH:mm:ss</logDateFormat>
              <logTimeZone>GMT+8:00</logTimeZone>
              <append>true</append>
              <logServer>true</logServer>
              <retainDays>120</retainDays>
              <logCookies>true</logCookies>
            </requestLog>
          </configuration>
        </plugin>
      </plugins>
      [...]
    </build>
    更多有关 jetty 的配置信息可参考 http://www.eclipse.org/jetty/documentation/current/jetty-maven-plugin.html
    原文地址 http://www.blogjava.net/fancydeepin/archive/2012/06/23/maven-jetty-plugin.html
  • 相关阅读:
    https://blog.csdn.net/yongchaocsdn/article/details/53355296
    P1526 [NOI2003]智破连环阵 [搜索+剪枝(二分图)]
    AT2165 Median Pyramid Hard [二分答案]
    翻煎饼 [迭代加深搜索+剪枝]
    P2962 [USACO09NOV]灯Lights [高斯消元+异或方程组 / 折半搜索]
    P5025 [SNOI2017]炸弹 [线段树优化建图 + Tarjan]
    Tarjan [割点, 缩点, 桥(待填坑)]
    线段树优化建图学习笔记
    P5468 [NOI2019]回家路线 [斜率优化dp]
    CF573E Bear and Bowling [平衡树+动态规划]
  • 原文地址:https://www.cnblogs.com/zyzcj/p/6392734.html
Copyright © 2020-2023  润新知