新聞中心
EJB調(diào)用是耗時(shí)、費(fèi)力的。怎么提高EJB性能?我們?yōu)榻鉀Q這一問(wèn)題,開(kāi)始邊寫(xiě)邊討論。等到完成了,我才發(fā)現(xiàn),我們所應(yīng)用的技巧總結(jié)一下,竟有十條。把提高EJB性能的這些技巧總結(jié)一下,為以后的項(xiàng)目做參考。

創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司,專(zhuān)注成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、網(wǎng)站營(yíng)銷(xiāo)推廣,國(guó)際域名空間,網(wǎng)站空間,成都網(wǎng)站托管有關(guān)企業(yè)網(wǎng)站制作方案、改版、費(fèi)用等問(wèn)題,請(qǐng)聯(lián)系創(chuàng)新互聯(lián)。
1.用一個(gè)Session Bean封裝多個(gè)Entity Bean,將原來(lái)的多個(gè)Entity Bean的Remote調(diào)用和Local調(diào)用封裝在一個(gè)Session Bean中。所以建立一個(gè)ServerFacade,它為多個(gè)對(duì)象提供統(tǒng)一獲取EJB Home和獲取對(duì)象的接口。ServerFacade為程序要用到的所有EJB的home handle提供緩存,提高訪問(wèn)JNDI Name的時(shí)間,達(dá)到提高訪問(wèn)效率的目的。以后查找JNDI Name的方法都應(yīng)寫(xiě)在接口里,調(diào)用時(shí)直接從接口調(diào)用。
2.在EJB的Remote接口中使用粗粒度的方法,不推薦使用細(xì)粒度方法。
3.如果EJB的Remote接口獲取成功,應(yīng)不再使用Remote接口,而是將Remote接口構(gòu)造成一個(gè)一般的Java對(duì)象,通過(guò)調(diào)用一般的JAVA 對(duì)象的方法來(lái)達(dá)到減少對(duì)網(wǎng)絡(luò)的訪問(wèn)。
4.如果你部署EJB客戶(hù)端和EJB在相同的JVM上,建設(shè)使用EJB2.0規(guī)范的Local接口代替Remote接口。
5.用"transient"關(guān)鍵字聲明不必要的數(shù)據(jù)變量,替代以前的"public"、"private"等,避免不必要的數(shù)據(jù)變量占用網(wǎng)絡(luò)資源。示例:
- public class DemoCMP implements EntityBean {
- transient EntityContext entCtx;
- transient InitialContext initCtx;
- public String id;
- public String description;
- …
- }
6.在ejb-jar.XML部署文件中,對(duì)Session Bean中非事務(wù)的方法,將trans-attribute屬性賦為"NotSupported"或"Never"
- …
abookesessionBean * NotSupported
7.設(shè)置事務(wù)的超時(shí)時(shí)間,在JBoss中,要修改${jboss.home}/server/${jboss.configuration}/conf /jboss-service.xml ,如下所示:
- …
code="org.jboss.tm.TransactionManagerService" - name="jboss:service=TransactionManager">
name="TransactionTimeout">300 - …
8.當(dāng)事務(wù)鎖定數(shù)據(jù)庫(kù)的行記錄時(shí),事務(wù)應(yīng)跨越可能的最小的時(shí)間。
9.調(diào)整EJB 服務(wù)器的各種參數(shù),如線程數(shù)、EJB池大小、連接池參數(shù)等。以在JBoss修改連接池參數(shù)為示例,進(jìn)行說(shuō)明。如果JBoss和MySQL相連,配置${jboss.home}/server/${jboss.configuration}/deploy/mysql-service.xml,來(lái)修改連接池參數(shù),包括MinSize、MaxSize、BlockingTimeoutMillis、IdleTimeoutMinutes、 Criteria等,各參數(shù)的含義如下所示:
◆MinSize :連接池保持的最小連接數(shù)。
◆MaxSize :連接池保持的最大連接數(shù)。
◆BlockingTimeoutMillis :拋出異常前最大的等待連接時(shí)間。
◆IdleTimeoutMinutes :關(guān)閉連接前連接空閑的最大時(shí)間。
◆Criteria :有ByContainerAndApplication、ByContainer、ByApplication和ByNothing等值。
下面是一個(gè)例子:
optional-attribute-name="ManagedConnectionPool"> code="org.jboss.resource.connectionmanager.JBossManagedConnectionPool" - name="jboss.jca:service=LocalTxPool,name=MySqlDS">
name="MinSize">0 name="MaxSize">50 name="BlockingTimeoutMillis">5000 name="IdleTimeoutMinutes">15 name="Criteria">ByContainer
10.對(duì)于數(shù)據(jù)庫(kù)事務(wù),應(yīng)選擇較低成本的事務(wù)等級(jí),避免造成壞數(shù)據(jù)。遞增成本的事務(wù)等級(jí)包括:
TRANSACTION_READ_UNCOMMITED;
TRANSACTION_READ_COMMITED;
TRANSACTION_REPEATABLE_READ;
TRANSACTION_SERIALIZABLE;
以上是提高EJB性能的技巧,為以后的項(xiàng)目做參考。
【編輯推薦】
- 配置JBoss如何從數(shù)據(jù)庫(kù)里讀取信息
- JBoss Rules的入門(mén)學(xué)習(xí)
- 在JBoss下通過(guò)本地接口訪問(wèn)EJB
- JBoss的classLoader問(wèn)題
- 用Eclipse啟動(dòng)JBoss
文章題目:提高EJB性能十大技巧
路徑分享:http://m.5511xx.com/article/djppdgs.html


咨詢(xún)
建站咨詢(xún)
