网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>JAVA>>新手入门>>基础入门>查看文档  
  最佳实践:避免或最小化 servlet 中的同步     
  文章作者:未知  文章来源:水木森林  
  查看:109次  录入:管理员--2007-11-17  
 
  关键字:servlet,jsp

摘要

最小化 servlet 中同步的使用。因为 servlet 是多线程的,主要代码路径的同步会严重地且极为有害地影响性能。

建议

servlet 是多线程的。基于 servlet 的应用程序必须认识并适当地处理这一点。如果应用程序有很多大段的代码是同步的,那么这个应用程序实际上就变成单线程的,而且吞吐量会显著下降。

在 servlet 中不出现同步是最佳选择,然而,如果应用程序设计无法避免同步,那么请使用“锁对象(lock object)”并且锁定可用性最小的代码路径。请不要同步 servlet 的 service 方法或 doget 以及 dopost 方法。这些方法是主要代码路径。同步这些方法或任何这些 servlet 方法之一将锁定整个 servlet 实例。下列代码显示了一个使用“锁对象”来保护 servlet 实例变量 numberofrows 的示例。

最小同步代码路径

public class bpallbadthingsservletsv1b extends httpservlet
{
private int numberofrows = 0;
private javax.sql.datasource ds = null;

private object lockobject = new object();

public void doget(httpservletrequest request, httpservletresponse response)
throws servletexception, ioexception
{
connection conn = null;
resultset rs = null;
preparedstatement pstmt = null;
int startingrows = 0;

synchronize(lockobject)
{
startingrows = numberofrows;
}
try
{
string employeeinformation = null;
conn = ds.getconnection("db2admin", "db2admin");
pstmt = conn.preparestatement
("select * from db2admin.employee");
rs = pstmt.executequery();
}
catch (exception es)
{
// error handling code here
}
}
}

应被取代的方法

以下代码显示如何同步主要代码路径来保护称为 numberofrows 的 servlet 实例变量。

使用 javax.servlet.singlethreadmodel 仍是另一种保护 servlet 实例变量的方法,但最好还是避免使用这种方法。

下面的图 1 显示了同步的性能影响

锁定主要代码路径:过度的同步

public class bpallbadthingsservletsv1a extends httpservlet
{
private int numberofrows = 0;
private javax.sql.datasource ds = null;

public void doget(httpservletrequest request, httpservletresponse response)
throws servletexception, ioexception
{
connection conn = null;
resultset rs = null;
preparedstatement pstmt = null;
int startingrows;

try
{
synchronized(this) // locks out most of the servlet processing
{
startingrows = numberofrows;
string employeeinformation = null;
conn = ds.getconnection("db2admin", "db2admin");
pstmt = conn.preparestatement
("select * from db2admin.employee");
rs = pstmt.executequery();
}
}
catch (exception es)
{
// error handling code here
}
}
}

参考资料

websphere application server development best practices for performance and scalability
作者

harvey w. gunther 是 ibm 在北卡罗莱纳州 raleigh 的 websphere 产品开发小组中的资深性能分析师。可以通过 hgunther@us.ibm.com 与他联系。
 
 
上一篇: 足球战术之observer及memento篇    下一篇: 最佳实践:勿在 servlet 中实现 singlethreadmodel
  相关文档
值得思考的 j2ee 架构的6个最佳实践 11-17
如何把hibernate2.1升级到hibernate3.0 11-16
在robocode中使用vector实现敌人列表 11-17
eclipse入门使用指南及开发eclipse插件(6) 11-17
java基础学习 java中常用开发工具介绍 11-16
j2me学习系列之如何将j2me与xml集成 11-17
jsp学习记录(四)——scriptlet 11-17
在java中如何进行base64编码和解码 11-17
java事件处理与发送 11-17
漫谈java程序设计中的接口应用 11-16
开发框架:利用struts实现国际化支持 12-25
整合hibernate3与jboss 3.2.x 11-17
经典之谈:从追mm谈java的23种设计模式 11-17
从xml到java代码的数据绑定之对象 11-16
java认证考试 11-17
spring xml配置十二个最佳实践 11-17
基础:深入解析java的新特性assertion 12-12
jbuilder 7 weblogic 6.x 详细配置(2) 11-17
为j2me开发移动3d游戏之立即模式 11-16
在java中使用正则表达式 11-16
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
技术电话:13616026886
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息