快速业务通道

避免或最小化Servlet中的同步 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-21

避免或最小化Servlet中的同步

时间:2011-01-17 IBM Harvey W. Gunther

摘要

最小化 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         }    } }

避免或最小化Servlet中的同步(2)

时间:2011-01-17 IBM Harvey W. Gunther

应被取代的方法

以下代码显示如何同步主要代码路径来保护称为 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        }    } }

图 1 -- 性能影响 -- 同步

避免或最小化Servlet中的同步 - 编程入门网

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号