InfoQ

InfoQ

新闻

我的书签

登录注册 以永久保存书签。

该内容已经被标记书签!

标记书签错误,请重试!

开源Servlet容器Jetty 7.0发布

作者 Alex Blewitt 译者 胡键 发布于 2009年10月13日

领域
运维 & 基础架构,
语言 & 开发
主题
应用服务器 ,
Java ,
语言 ,
编程 ,
Web服务器 ,
Continuations ,
Jetty

10月8号,Jetty 7.0宣告发布,人们可由位于Eclipse.org上的新主页或通过Maven Repository下载。该版本不仅代表了Jetty 6.0的一次演变,而且还代表了代码库的重大调整和诸多性能改进。

InfoQ曾在今年早些时候报道过Jetty投入Eclipse的怀抱;在Jetty 6.0依旧还将得到支持的同时,新的特性将针对7.0开发。Jetty 6.0和7.0的基础都是Servlet 2.5 API;处于试验阶段的Jetty 8.0将支持Servlet 3.0 API,该规范有望于明年正式完成。

Jetty 6.0的一个关键特性是在Servlet层引入了延续(Continuation),这将使长活动的客户端连接(如那些使用了CometD——又被称为Bayeux协议——的连接)成为可能。InfoQ以前曾报道过Jetty 6.0的发布以及几个延续的示例,它们展示了在不向线程数目(以及相关开销)妥协的条件下,延续是如何被用来支持大规模并发用户的。

该技术的成功导致了Jetty建议在Servlet 3.0规范草案中加入异步Servlet。Jetty 7.0实现的这些延续既可以无需修改就运行于Servlet 3.0实现之上,同时还可以向后应用于非Jetty的Servlet 2.5实现(非异步、阻塞)中。

由于迁移到了Eclipse,因此代码也经过了重构(org.mortbay前缀已经被org.eclipse替换),而且单个的server.jar也已经被分割成几个组成部分(jetty-server.jarjetty-servlet.jarjetty-io.jar等)。模块化的一个附带好处是在不同的包之间带来了更多的强制的关注点分离,由此进而导致了更多的嵌入模块的方法。同时,Jetty现在是一系列有效的OSGi包(具备定义良好的依赖关系),它仍然可以运行在OSGi运行时之外。

迁移文档中描述了包中的这些不同;鉴于大量的类名已经改变,Jetty还提供了一个自动化工具来将配置文件中使用的类名转换成Jetty 7.0的新类名。未来的升级(如升级到Jetty 8.0)将会小得多,因为未来这些包不会再经历一次重命名和重新打包。

基于旧版本Jetty 6.0的cometd-jetty项目也已经过时,请使用基于Jetty 7.0的cometd-java,该项目现在已可从CometD.org访问。一份演示已经可供下载,它通过支持大数量的AJAX客户端(它们创建了连接到后端服务器的长活动连接),同时不增加负荷,展示了异步延续的好处。

最后,Jetty的创造者Webtide已于上月被Intalio收购)也宣布了名为Jetty-Hightide的开源产品,它包括了一系列开源组件库:

  • Glassfish的JSP
  • 来自atomikos的JTA
  • Maven plugin
  • Ant集成
  • Spring配置
  • Setuid

当前可供下载的Hightide版本是以Jetty 6.0为基础的,但在不久之后,将会提供一份包含Jetty 7.0的修订版。

Jetty可以在双许可证下获得,包括Apache License 2.0,以及来自www.eclipse.org/jettyEclipse Public License 1.0。此外,针对其他平台的Jetty包还可以从Codehaus获得,如用于Linux系统的RPMsDebs

查看英文原文:Jetty 7.0 released

译者 胡键 热心开源技术,《开源技术选型手册》作者,《SOA实践指南》译者。目前致力于Groovy/Grails的研究和推广。