开源 Servlet 容器 Jetty 7.0 发布

  • Alex Blewitt
  • 胡键

2009 年 10 月 13 日

话题:JavaDevOps语言 & 开发

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

JavaDevOps语言 & 开发