二、Jetty的配置说明
运行Jetty Web应用
在Jetty应用服务器中部署war项目很简单,只需把项目war包放入Jetty的webapps子目录即可。你都无需重启Jetty,Jetty会自动随时监听webapps目录,自动完成新项目的部署。
一、Jetty目录剖析
bin:可执行脚本文件
demo- base:
etc:Jetty模块定义的XML配置文件的目录
lib:Jetty依赖的库文件
logs:Jetty的日志目录
modules:Jetty的模块
resources:外部资源配置文件的目录
webapps:项目WAR文件的目录
还需要关心根目录下的一个文件:start.d(Wondows系统是start.ini文件),它定义了Jetty的活动模块。
二、基本配置
1、修改Jetty的端口
Jetty默认使用8080端口,要让它使用其他端口(如7070),那么编辑start.d(Wondows系统是start.ini文件),找到jetty.http.port行,修改为:
## Connector port to listen on
jetty.http.port=7070
保存并退出,再重启Jetty。
2、修改webapps目录
Jetty下的webapps是默认的Web项目的部署目录,如果想修改此目录,可修改start.d配置文件(start.ini),移除以下行的注释符号“#”
# jetty.deploy.monitoredDir=webapps
并把内容修改到你指定的目录。保存并退出,再重启Jetty。
六、Jetty的模块化架构
Jetty运行于模块化的架构之上,这意味着Jetty的功能是以模块的方式运行的,比如HTTP、HTTPS、SSL、日志logging、JMX、JNDI、WebSocket等模块。常用的模块如HTTP、JSP和WebSocket模块都是默认就激活的,而其他如HTTPS、JMX等模块则需要手动激活。
1、单个模块的剖析
Jetty的modules子目录列出了所有的模块,这些模块是扩展名为.mod的文件,它声明了要被激活的JAR文件(在Jetty的lib子目录下)和XML配置文件(在Jetty的etc子目录下),以及其他要作为模块被激活的资源。
比如,可以查看modules子目录的logging.mod文件的内容,可以看到,它声明了配置文件是etc/jetty-logging.xml,所需的JAR包在lib/logging处,另外logs目录是必须的。
[ xml]
etc/jetty-logging.xml
[files]
logs/
[lib]
lib/logging/**.jar
resources/
2、通过命令行激活模块
激活Jetty的模块有两种方式。
第一种方式是通过命令行激活:
java -jar start.jar --add-to-startd=logging
上面的命令会在Jetty目录下创建logging.ini文件,相关的配置可以在此文件中查到。配置日志后,可以再次启动Jetty,并可以查看到日志模块是激活了的。
2、通过配置文件start.ini激活模块
第二种方式是通过配置文件start.ini激活模块
--module=logging
这种方式和前一种相似,且更常用。
3、配置模块
正如上面提到的,mod文件声明了相关的XML配置文件,在Jetty的etc子目录下,可以通过这些配置文件来配置模块。比如日志模块声明了相关的配置文件是jetty-logging.xml,可以通过修改此配置文件来调整日志。
=============================================================
Jetty 的基本配置
Jetty 的基本配置与 Tomcat类似,在这里主要介绍 Jetty 的端口设置及如何部署 Web应用。由于 Jetty 是个嵌入式 Web 服务器,因此设置方式比较特殊。
Jetty 的配置文件放在 etc 路径下,该路径下有如下几个配置文件:
jetty.xml文件。
jetty-jmx.xml文件。
jetty-plus.xml文件。
webdefault.xml文件。
其中 webdefault.xm1文件是 Web 应用的默认配置文件,与 Jetty 的配置没有太大的关系,该文件通常不需要修改。
另外的三个都是 Tomcat 的配置文件:jetty.xml文件是默认的配置文件;jetty-jmx.xml是启动 JMX 控制的配置文件; jetty-plus.xm1文件是在增加 Jetty 扩展功能的配置文件。在启动 Jetty 时输入如下命令:
java -jar startup.jar |
默认使用jetty.xm1文件时启动Jetty,即与如下命令效果相同:
java -jar startup.jar etc/jetty.xml |
启动时也可以指定多个配置文件,可输入如下命令:
java -jar startup.jaretc/jetty.xml etc/jetty-plus.xml |
打开 Jetty 配置文件,该配置文件的根元素是Configure,另外还会看到有如下的配置元素。
Set: 相当于调用 setxx 方法。
Get: 相当于调用 getXxx 方法。
New: 创建某个类的实例。
Arg: 为方法或构造器传入参数。
Array: 设置一个数组。
Item: 设置数组或集合的-J页。
Call: 调用某个方法。
Jetty 是个嵌入式 Web 容器,因此它的服务对应一个 Server 实例,可以看到配置文件中有如下片段:
<!--配置了一个Jetty服务器进程--> |
1. 配置 Jetty服务端口
Configure元素里的各种子元素,即对该Server实例的操作。在Configure元素下有如下代码所示的 Set 子元素, Set 子元素的 name 属性为 connectors,效果等同于调用setConnectors方法,用于设置Web 服务的提供端口。该方法需要Connector数组,其包含的 Array 子元素则用于设置该方法的参数。Array元素里的Item子元素,则是数组的数据项,每个Connector对应一个连接提供者。
<!--类似于调用setConnectors方法--> <Set name="Acceptors">l</Set> <!--如果Java 的nio不可用,则使用如下的Connector--> <!-- <!-- |
在上面的配置片段中,默认第一个Connector是有效的,该Connector就是常规Web服务的Connector,其中的8080就是Jetty 的默认端口。
笔者将该片段修改如下:
<!--下面的 Connector提供常见的Web服务--> |
修改成上面所示的样例后,Jetty 的服务端口为88860 这也是笔者所使用的端口。
2. 部署 Web应用
Jetty也支持自动部署和配置文件部署。
如果使用默认的配置文件启动,webapps 会自动部署目录。即所有存放在webapps路径的Web应用将自动部署在Jetty容器中。
如果使用带Jetty扩展功能来启动,~P增加jetty-plus.xrnl文件来启动,则webapps-plus也会自动部署目录,将所有放在该路径的Web应用自动部署在Jetty容器中。下面看如何使用配置文件来部署Web应用。
部署 Web 应用需使用 org.mortbay.jetty.webapp.WebAppContext,该类的实例即对应一个 Web 应用,并且该类还包含多个静态的重载方法:addWebApplications。该方法用于同时部署多个Web应用,即用于配置一个自动部署目录。
jetty.xrnl配置文件的片段如下:
<!--调用 WebAppContext 的静态方法addWebApplications--> |
通过查看该配置文件不难发现,在每次调用addWebApplications方法后,即可增加一个Web应用的自动部署路径。如有必要,用户完全可以增加自己的自动部署路径,如果增加了自动部署路径,则所有在该路径下的Web应用将自动部署。
如果仅需要部署一个Web应用,可以有如下两种方法:
·修改jetty.xml文件。
·增加自己的配置文件。
根据前面的介绍,对于Web服务器,应尽量避免修改默认的配置文件。如果读者真需要通过修改jetty.xml文件来部署Web应用,则应在jetty 的 Configure元素下增加如下片段:
<!-- 创建一个Web应用--> <!--三个构造参数--> |
注意:该代码片段在jetty.xml文件仅仅被注释,只要取消该代码片段注释即可。但需要注意: jetty.xml文件默认有个小错误,它的设直超时时长的Set元素的 name属性值为 maxInactivelntervale。实际上HashSessionManager并没有setMaxInactiveIntervale方法,通 过查看API 文档发现,它包含一个setMaxInactiveInterval方法(最后少一个e),读者将原有的e 删除即可。
通常建议增加自己的配置文件,应尽量避免修改系统原有的配置文件。增加的配置文件如下:
<?xml version="1.0"encod工ng="gb2312"?> <!--创建一个Web应用--> |
将该配置文件保存在etc 路径下,以后每次启动Jetty 时,可直接加载该配置文件,使用如下启动命令即可(假设该配置文件的文件名为jetty-yeeku.xml):
java -jar startup.jar etc/jetty.xml etc/jetty-yeeku.xml |
3. 配置 JNDI 绑定
Jetty 同样可以整合 DBCP、 C3PO 等数据源来提供容器管理的数据源。提供容器管理的数据源,只是 Jetty JNDI 绑定功能之一。
下面介绍如何在 Jetty 绑定 JNDI,以及 JNDI 的使用。
增加 JNDI 绑定必须使用 Jetty 的 plus 功能。因此,启动时必须增加 jetty-plus.xml
文件。增加 JNDI 的绑定同样有两个方法:
·修改系统默认的jetty.xml 文件。
·增加自己的配置文件。
两种配置方式大同小异,区别是前者需要修改系统默认的配置文件,此处仅介绍增加自己的配置文件方式。
在 Jetty 的 plus 中,有如下包。
org.mortbay.jetty.plus.naming:执行JNDI绑定的包。
该包下有如下四个类。
EnvEntry: 绑定简单值。
NamingEntry: 抽象类,是另外三个类的父类。
Resource: 用于绑定数据源等资源。
Transaction: 用于绑定事务。
增加数据源绑定请按如下步骤进行。
(1)此处绑定的数据源依然以 DBCP 为实现,当然也可以绑定 C3PO 数据源,但必须将 DBCP 所需要的 jar文件复制到 Jetty 可以使用的路径中。根据前面介绍 DBCP 主要需要如下三个文件:
commons-dbcp.jar |
将这三个文件复制到 Jetty 的 lib 路径下即可, Jetty 启动时会自动加载该路径的jar文件。当然,还需将数据库驱动复制到该路径下。
(2) 增加如下配置文件:
<?xml version="l.0"?> |
在上面的配置文件中,绑定了三个JNDI值,下面测试该JNDI 的 Servlet:
public class TestServlet extends HttpServlet |
启动 Jetty,访问该Servlet,即看到数据库的访问结果。
二、Jetty的配置说明的更多相关文章
- Java web项目搭建系列之二 Jetty下运行项目
在项目pom.xml文件中添加Jetty运行配置 在pom.xml文件project节点下插入如下代码: <build> <plugins> <plugin> &l ...
- Zookeeper系列(二) Zookeeper配置说明
在配置ZooKeeper配置文件时,有些参数是必需的,有些参数是可选的,这些必需的参数构成了Zookeeper配置文件的最低配置要求,如果需要对ZooKeeper进行更详细的配置,可以 ...
- 嵌入式jetty
一.maven依赖 pom配置 <dependency> <groupId>org.eclipse.jetty</groupId> <artifactId&g ...
- Jetty和Tomcat的使用及性能测试
一 测试目的 这次对Jetty和Tomcat进行性能测试,主要是为了给新版本WebPortal的开发选择合适的Java Web Server. 我们之前对老的Rest和新的TMMI都进行过性能测试,R ...
- eclipse中jetty插件安装
注:本文来源于:<eclipse中jetty插件安装> 一.eclipse中jetty插件安装: 打开eclipse,依次点击菜单Help->Eclipse Marketplace, ...
- eclips如何安装jetty插件
转载自http://www.cnblogs.com/nightswatch/p/4639687.html的博文 eclipse中安装jetty插件并使用 一.eclipse中jetty插件安装: ...
- eclipse中安装jetty插件并使用
一.eclipse中jetty插件安装: 打开eclipse,依次点击菜单Help->Eclipse Marketplace,在Find后面的框中输入jetty,选择第一项进行install即可 ...
- 使用Nexus配置Maven私有仓库
使用Nexus配置Maven私有仓库 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.安装配置Nexus 1>.下载nexus 下载地址:https://www.sonat ...
- redis AND memcache
memcache文章索引 MEMCACHE问题集锦[转] MEMCACHED 高可用方案 REPCACHED NOSQL之[MEMCACHED]学习 当 MySQL 和 Memcached 遇到尾部空 ...
随机推荐
- 添加git 忽略文件
在使用Git的过程中,我们喜欢有的文件比如日志,临时文件,编译的中间文件等不要提交到代码仓库,这时就要设置相应的忽略规则,来忽略这些文件的提交. Git 忽略文件提交的方法 有三种方法可以实现忽略Gi ...
- PHP sessions that have already been started
In my PHP code, if a session has already started, and I try to start a new one, I get the following ...
- losetup命令
Linux losetup命令用于设置循环设备. 循环设备可把文件虚拟成区块设备,籍以模拟整个文件系统,让用户得以将其视为硬盘驱动器,光驱或软驱等设备,并挂入当作目录来使用. 语法 losetup [ ...
- Why ZK
ZooKeeper是一个开放源代码的分布式协调服务,由知名互联网公司雅虎创建,是Google Chubby的开源实现.ZooKeeper的设计目标是将那些复杂且容易出错的分布式一致性服务封装起来,构成 ...
- postfix邮件服务器搭建02-安装篇
本文接着上文的环境,进行postfix邮件发信端和dovecot邮件收信端的部署,之后部署基于浏览器的extmail图形管理端,使管理员可以通过网页对邮件虚拟用户进行管理,对邮件服务器进行管控 1.p ...
- 【剑指offer】第一个只出现一次的字符
原创博文,转载请注明出处!本题牛客网地址 博客文章索引地址 博客文章中代码的github地址 1.题目 2.思路 空间换时间.建立一个哈希表,第一次扫描字符串时,统计每个字符的出现次数.第二次扫描字符 ...
- TCP/IP 必知必会的十个问题
本文整理了一些TCP/IP协议簇中需要必知必会的十大问题,既是面试高频问题,又是程序员必备基础素养. 一.TCP/IP模型 TCP/IP协议模型(Transmission Control Protoc ...
- lua不支持的泛型方法
1.没有泛型约束 2.缺少带约束的泛型参数 3.泛型约束必须为class /// <summary> /// 不支持生成lua的泛型方法(没有泛型约束) /// </summary& ...
- wamp配置局域网访问
Apache的版本是2.4.9. <Directory "D:/wamp/www/"> # # Possible values for the Option ...
- CentOS 7.0 yum安装Apache、PHP和MySQL
centos7默认将mariadb视作mysql. p.s.因为mysql被oracle收购后,原作者担心mysql闭源,所以又写了一个mariadb,这个数据库可以理解为mysql的分支. 卸载ma ...