Java 性能優化技巧集錦 (2)

前面介紹的改善性能技巧適合於大多數Java應用,接下來要討論的問題適合於使用JSP、EJB或JDBC的應用。

1. 使用緩衝標記

一些應用服務器加入了面向JSP的緩衝標記功能。例如,BEA的WebLogic Server從6.0版本開始支持這個功能,Open Symphony工程也同樣支持這個功能。JSP緩衝標記既能夠緩衝頁面片斷,也能夠緩衝整個頁面。當JSP頁面執行時,如果目標片斷已經在緩衝之中,則生成該片斷的代碼就不用再執行。頁面級緩衝捕獲對指定URL的請求,並緩衝整個結果頁面。對於購物籃、目錄以及門戶網站的主頁來說,這個功能極其有用。對於這類應用,頁面級緩衝能夠保存頁面執行的結果,供後繼請求使用。

對於代碼邏輯複雜的頁面,利用緩衝標記提高性能的效果比較明顯;反之,效果可能略遜一籌。

2. 始終通過會話Bean訪問實體Bean

直接訪問實體Bean不利於性能。當客戶程序遠程訪問實體Bean時,每一個get方法都是一個遠程調用。訪問實體Bean的會話Bean是本地的,能夠把所有數據組織成一個結構,然後返回它的值。

用會話Bean封裝對實體Bean的訪問能夠改進事務管理,因爲會話Bean只有在到達事務邊界時纔會提交。每一個對get方法的直接調用產生一個事務,容器將在每一個實體Bean的事務之後執行一個“裝入-讀取”操作。一些時候,使用實體Bean會導致程序性能不佳。如果實體Bean的唯一用途就是提取和更新數據,改成在會話Bean之內利用JDBC訪問數據庫可以得到更好的性能。

3. 選擇合適的引用機制

在典型的JSP應用系統中,頁頭、頁腳部分往往被抽取出來,然後根據需要引入頁頭、頁腳。當前,在JSP頁面中引入外部資源的方法主要有兩種:include指令,以及include動作。

include指令:例如

<%@ include file="copyright.html" %>


該指令在編譯時引入指定的資源。在編譯之前,帶有include指令的頁面和指定的資源被合併成一個文件。被引用的外部資源在編譯時就確定,比運行時才確定資源更高效。

include動作:例如

<jsp:include page="copyright.jsp" />


該動作引入指定頁面執行後生成的結果。由於它在運行時完成,因此對輸出結果的控制更加靈活。但時,只有當被引用的內容頻繁地改變時,或者在對主頁面的請求沒有出現之前,被引用的頁面無法確定時,使用include動作才合算。

4. 在部署描述器中設置只讀屬性

實體Bean的部署描述器允許把所有get方法設置成“只讀”。當某個事務單元的工作只包含執行讀取操作的方法時,設置只讀屬性有利於提高性能,因爲容器不必再執行存儲操作。

(原作者:Java Research)

5. 緩衝對EJB Home的訪問

EJB Home接口通過JNDI名稱查找獲得。這個操作需要相當可觀的開銷。JNDI查找最好放入Servlet的init()方法裏面。如果應用中多處頻繁地出現EJB訪問,最好創建一個EJBHomeCache類。EJBHomeCache類一般應該作爲singleton實現。

6. 爲EJB實現本地接口

本地接口是EJB 2.0規範新增的內容,它使得Bean能夠避免遠程調用的開銷。請考慮下面的代碼。

PayBeanHome home = (PayBeanHome)
javax.rmi.PortableRemoteObject.narrow
(ctx.lookup ("PayBeanHome"), PayBeanHome.class); 
PayBean bean = (PayBean)
javax.rmi.PortableRemoteObject.narrow 
(home.create(), PayBean.class);


第一個語句表示我們要尋找Bean的Home接口。這個查找通過JNDI進行,它是一個RMI調用。然後,我們定位遠程對象,返回代理引用,這也是一個RMI調用。第二個語句示範瞭如何創建一個實例,涉及了創建IIOP請求並在網絡上傳輸請求的stub程序,它也是一個RMI調用。要實現本地接口,我們必須作如下修改:

方法不能再拋出java.rmi.RemoteException異常,包括從RemoteException派生的異常,比如TransactionRequiredException、TransactionRolledBackException和NoSuchObjectException。EJB提供了等價的本地異常,如TransactionRequiredLocalException、TransactionRolledBackLocalException和NoSuchObjectLocalException。

所有數據和返回值都通過引用的方式傳遞,而不是傳遞值。本地接口必須在EJB部署的機器上使用。簡而言之,客戶程序和提供服務的組件必須在同一個JVM上運行。如果Bean實現了本地接口,則其引用不可串行化。
發佈了0 篇原創文章 · 獲贊 0 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章