`
windelk
  • 浏览: 15386 次
  • 性别: Icon_minigender_2
  • 来自: 福州
社区版块
存档分类
最新评论

[转载][优化]Servlet应用程序优化的八种方法

阅读更多
 
发布时间:2007.05.21 05:26     来源:赛迪网技术社区    作者:dxaw

你 的J2EE应用是不是运行的很慢?它们能不能承受住不断上升的访问量?本文讲述了开发高性能、高弹性的JSP页面和Servlet的性能优化技术。其意思 是建立尽可能快的并能适应数量增长的用户及其请求。在本文中,我将带领你学习已经实践和得到证实的性能调整技术,它将大大地提高你的servlet和 jsp页面的性能,进而提升J2EE的性能。这些技术的部分用于开发阶段,例如,设计和编码阶段。另一部分技术则与配置相关。

 

技术1:在HttpServletinit()方法中缓存数据

 

服务器会在创建servlet实例之后和servlet处理任何请求之前调用 servlet的init()方法。该方法在servlet的生命周期中仅调用一次。为了提高性能,在init()中缓存静态数据或完成要在初始化期间完 成的代价昂贵的操作。例如,一个最佳实践是使用实现了javax.sql.DataSource接口的JDBC连接池。

 

DataSource从JNDI树中获得。每调用一次SQL就要使用JNDI查找DataSource是非常昂贵的工作,而且严重影响了应用的性能。Servlet的init()方法可以用于获取DataSource并缓存它以便之后的重用:

 

publicclassControllerServletextendsHttpServlet
{
privatejavax.sql.DataSourcetestDS=null;

publicvoidinit(ServletConfigconfig)throwsServletException
{
super.init(config);
Contextctx=null;
try
{
ctx=newInitialContext();
testDS=(javax.sql.DataSource)ctx.lookup("jdbc/testDS");
}
catch(NamingExceptionne)
{
ne.printStackTrace();
}
catch(Exceptione)
{
e.printStackTrace();
}
}

publicjavax.sql.DataSourcegetTestDS()
{
returntestDS;
}
...
...
}

 

技术2:禁用servlet和Jsp的自动装载功能

 

当每次修改了Servlet/JSP之后,你将不得不重新启动服务器。由于自动装载 功能减少开发时间,该功能被认为在开发阶段是非常有用的。但是,它在运行阶段是非常昂贵的;servlet/JSP由于不必要的装载,增加类装载器的负担 而造成很差的性能。同样,这会使你的应用由于已被某种类装载器装载的类不能和当前类装载器装载的类不能相互协作而出现奇怪的冲突现象。因此,在运行环境中 为了得到更好的性能,关闭servlet/JSP的自动装载功能。

 

技术3:控制HttpSession

 

许多应用需要一系列客户端的请求,因此他们能互相相关联。由于HTTP协议是无状态 的,所以基于Web的应用需要负责维护这样一个叫做session的状态。为了支持必须维护状态的应用,Javaservlet技术提供了管理 session和允许多种机制实现session的API。HttpSession对象扮演了session,但是使用它需要成本。无论何时 HttpSession被使用和重写,它都由servlet读取。你可以通过使用下面的技术来提高性能:

l在JSP页面中不要创建默认的HttpSession:默认情况下,JSP页面创建HttpSession。如果你在JSP页面中不用HttpSession,为了节省性能开销,使用下边的页面指令可以避免自动创建HttpSession对象:

<%@pagesession="false"%>

 

1) 不要将大的对象图存储在HttpSession中:如果你将数据当作一个大的对象图存储在HttpSession中,应用服务器每次将不得不处理整个 HttpSession对象。这将迫使Java序列化和增加计算开销。由于序列化的开销,随着存储在HttpSession对象中数据对象的增大,系统的 吞吐量将会下降。

 

2) 用完后释放HttpSession:当不在使用HttpSession时,使用HttpSession.invalidate()方法使sesion失效。

 

3) 设置超时值:一个servlet引擎有一个默认的超时值。如果你不删除session或者一直把session用到它超时的时候,servlet引擎将把 session从内存中删除。由于在内存和垃圾收集上的开销,session的超时值越大,它对系统弹性和性能的影响也越大。试着将session的超时 值设置的尽可能低。

 

技术4:使用gzip压缩

 

压缩是删除冗余信息的作法,用尽可能小的空间描述你的信息。使用gzip (GNUzip)压缩文档能有效地减少下载HTML文件的时间。你的信息量越小,它们被送出的速度越快。因此,如果你压缩了由你web应用产生的内容,它 到达用户并显示在用户屏幕上的速度就越快。不是任何浏览器都支持gzip压缩的,但检查一个浏览器是否支持它并发送gzip压缩内容到浏览器是很容易的事 情。下边的代码段说明了如何发送压缩的内容。

 

publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)
throwsIOException,ServletException
{

OutputStreamout=null

//ChecktheAccepting-EncodingheaderfromtheHTTPrequest.
//Iftheheaderincludesgzip,chooseGZIP.
//Iftheheaderincludescompress,chooseZIP.
//Otherwisechoosenocompression.

Stringencoding=request.getHeader("Accept-Encoding");

if(encoding!=null&&encoding.indexOf("gzip")!=-1)
{
response.setHeader("Content-Encoding","gzip");
out=newGZIPOutputStream(response.getOutputStream());
}
elseif(encoding!=null&&encoding.indexOf("compress")!=-1)
{
response.setHeader("Content-Encoding","compress");
out=newZIPOutputStream(response.getOutputStream());
}
else
{
out=response.getOutputStream();

}
...
...
}

 

技术5:不要使用SingleThreadModel

 

SingleThreadModel保证servlet一次仅处理一个请求。如果一 个servlet实现了这个接口,servlet引擎将为每个新的请求创建一个单独的servlet实例,这将引起大量的系统开销。如果你需要解决线程安 全问题,请使用其他的办法替代这个接口。SingleThreadModel在Servlet2.4中是不再提倡使用。

 

技术6:使用线程池

 

servlet引擎为每个请求创建一个单独的线程,将该线程指派给service ()方法,然后在service()方法执行完后删除该线程。默认情况下,servlet引擎可能为每个请求创建一个新的线程。由于创建和删除线程的开销 是很昂贵的,于是这种默认行为降低了系统的性能。我们可以使用线程池来提高性能。根据预期的并发用户数量,配置一个线程池,设置好线程池里的线程数量的最 小和最大值以及增长的最小和最大值。起初,servlet引擎创建一个线程数与配置中的最小线程数量相等的线程池。然后servlet引擎把池中的一个线 程指派给一个请求而不是每次都创建新的线程,完成操作之后,servlet引擎把线程放回到线程池中。使用线程池,性能可以显著地提高。如果需要,根据线 程的最大数和增长数,可以创建更多的线程。

 

技术7:选择正确的包括机制

 

在JSP页面中,有两中方式可以包括文件:包括指令(<%@includefile ="test.jsp"%>)和包括动作(<jsp:includepage="test.jsp"flush="true"/>)。包括指令在编译阶段 包括一个指定文件的内容;例如,当一个页面编译成一个servlet时。包括动作是指在请求阶段包括文件内容;例如,当一个用户请求一个页面时。包括指令 要比包括动作快些。因此除非被包括的文件经常变动,否则使用包括指令将会获得更好的性能。

 

技术8:在useBean动作中使用合适的范围

 

使用JSP页面最强大方式之一是和JavaBean组件协同工作。JavaBean使用<jsp:useBean>标签可以嵌入到JSP页面中。语法如下:

 

<jsp:useBeanid="name"scope="page|request|session|application"class=
"package.className"type="typeName">
</jsp:useBean>

 

scope属性说明了bean的可见范围。scope属性的默认值是page。你应该根据你应用的需求选择正确的范围,否则它将影响应用的性能。

 

例如,如果你需要一个专用于某些请求的对象,但是你把范围设置成了session, 那么那个对象将在请求结束之后还保留在内存中。它将一直保留在内存中除非你明确地把它从内存中删除、使session无效或session超时。如果你没 有选择正确的范围属性,由于内存和垃圾收集的开销将会影响性能。因此为对象设置合适的范围并在用完它们之后立即删除。

 

杂项技术

 

1) 避免字符串连接:由于String对象是不可变对象,使用“+”操作符将会导致创建大量的零时对象。你使用的“+”越多,产出的零时对象就越多,这将影响性能。当你需要连接字符串时,使用StringBuffer替代“+”操作。

 

2) 避免使用System.out.println:System.out.println同步处理磁盘输入/输出,这大大地降低了系统吞吐量。尽可能地避免 使用System.out.println。尽管有很多成熟的调试工具可以用,但有时System.out.println为了跟踪、或调试的情况下依然 很有用。你应该配置System.out.println仅在错误和调试阶段打开它。使用finalBoolean型的变量,当配置成false时,在编 译阶段完成优化检查和执行跟踪输出。

 

3) ServletOutputStream与PrintWriter比较:由于字符输出流和把数据编码成字节,使用PrintWriter引入了小的性能开 销。因此,PrintWriter应该用在所有的字符集都正确地转换做完之后。另一方面,当你知道你的servlet仅返回二进制数据,使用 ServletOutputStream,因为servlet容器不编码二进制数据,这样你就能消除字符集转换开销。

分享到:
评论

相关推荐

    TOMCAT源代码,包括转载得别人的分析

    Apache Tomcat是一款开源的Java Servlet容器,用于部署和运行Java Web应用程序。它的源代码是公开的,这使得开发者能够深入理解其内部工作原理,优化性能,或者为它添加自定义功能。以下是对Tomcat源码及其分析的...

    JDBC连接DB2数据库详解.doc--转载

    一种优化方法是在Servlet中创建连接,然后传递给JSP页面,这有助于代码的管理和性能提升。DB2连接速度变慢或服务器崩溃可能与DB2实例和数据库参数配置不当有关,需要进一步调整。 DB2 UDB支持多种应用程序开发方式...

    Spring-Security-3应用的11个步骤.docx

    Spring Security 是一个强大的和高度可定制的身份验证和访问控制框架,用于保护基于 Java 的应用程序,尤其是J2EE企业级应用。它起源于2003年的Acegi Security,现在是Spring生态系统的组成部分,最新的版本是3.x。...

    三种Web开发主流技术ASP-PHP-JSP的评价[转载] --希望给大家作为参考.txt

    PHP具有高效、灵活且易于学习的特点,被广泛应用于构建动态网站和应用程序。 **特点** 1. **学习成本低**:PHP语法简单,易于理解,对于初学者来说非常友好。 2. **高效的执行速度**:PHP通常通过Apache服务器作为...

    Java 最常见 200+ 面试题全解析:面试必备.pdf

    15. Kafka:作为高性能的分布式消息系统,Kafka用于构建实时的数据管道和流应用程序,了解其生产者和消费者模型。 16. Zookeeper:分布式协调服务,主要管理分布式环境中的数据,如配置信息、命名服务、分布式锁等...

    Java实现文件下载

    在Java编程环境中,实现文件下载是一项常见的任务,尤其在Web应用程序开发中。下面将详细讲解如何使用Java来实现文件的下载功能。 首先,我们需要理解文件下载的基本原理。当用户通过浏览器点击一个链接时,服务器...

    j2ee在线购物网实例源码

    【压缩包子文件的文件名称列表】: "ESHop"可能代表了该实例源码的主项目目录或应用程序名。在这个目录下,可能会包含以下子目录和文件: 1. **Web-INF**: 这是放置Web应用配置文件的地方,如web.xml(部署描述符)...

    Linux一键安装web环境全攻略

    - 一种流行的开源关系型数据库管理系统,适合Web应用程序的数据存储。 - **PHP**: - 版本: 5.2.17、5.3.29、5.4.23、5.5.7 - 用于Web开发的服务器端脚本语言,支持多种数据库接口。 - **PHP扩展**: - memcache: ...

    JAVA计算机管理系统

    意味着它可能采用了Java SE(标准版)作为后端基础,用于服务器端的逻辑处理,可能还结合了Java EE(企业版)的部分组件,如Servlet、JSP、EJB等,来构建Web应用程序。此外,也可能使用了Spring、MyBatis等流行的...

Global site tag (gtag.js) - Google Analytics