首頁 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡(luò)課程 模擬考試 考友錄 實(shí)用文檔 繽紛校園 英語學(xué)習(xí)
2010考研 | 自學(xué)考試 | 成人高考 | 專 升 本 | 法律碩士 | MBA/MPA | 中 科 院
四六級(jí) | 商務(wù)英語 | 公共英語 | 職稱日語 | 職稱英語 | 博思 | 口譯筆譯 | GRE GMAT | 日語 | 托福
雅思 | 專四專八 | 新概念 | 自考英語 | 零起點(diǎn)英、、韓語 | 在職申碩英語
在職攻碩英語 | 成人英語三級(jí)
等級(jí)考試 | 水平考試 | 微軟認(rèn)證 | 思科認(rèn)證 | Oracle認(rèn)證 | Linux認(rèn)證
公務(wù)員 | 報(bào)關(guān)員 | 報(bào)檢員 | 外銷員 | 司法考試 | 導(dǎo)游考試 | 教師資格 | 國(guó)際商務(wù)師 | 跟單員
單證員 | 物流師 | 價(jià)格鑒證師 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 人力資源管理師 | 管理咨詢師
期貨從業(yè)資格 | 社會(huì)工作者
會(huì)計(jì)職稱 | 注會(huì)CPA | 經(jīng)濟(jì)師 | 統(tǒng)計(jì)師 | 注冊(cè)稅務(wù)師 | 評(píng)估師 | 精算師 | 高會(huì) | ACCA | 審計(jì)師
法律顧問 | 會(huì)計(jì)證
一級(jí)建造師 | 二級(jí)建造師 | 造價(jià)師 | 監(jiān)理師 | 安全師 | 咨詢師 | 結(jié)構(gòu)師 | 建筑師 | 安全評(píng)價(jià)師
房地產(chǎn)估價(jià)師 | 土地估價(jià)師 | 設(shè)備監(jiān)理師 | 巖土工程師 | 質(zhì)量資格 | 房地產(chǎn)經(jīng)紀(jì)人 | 造價(jià)員
投資項(xiàng)目管理 | 土地代理人 | 環(huán)保師 | 環(huán)境影響評(píng)價(jià) | 物業(yè)管理師 | 城市規(guī)劃師 | 公路監(jiān)理師
公路造價(jià)工程師 | 招標(biāo)師
執(zhí)業(yè)護(hù)士 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 衛(wèi)生資格

XXXX項(xiàng)目hibernate與應(yīng)用緩存方案總結(jié)

XXXX項(xiàng)目緩存方案總結(jié)

    XXXX項(xiàng)目是目前在實(shí)際工作中正在做的事情,該項(xiàng)目是一個(gè)大型系統(tǒng)的內(nèi)容管理內(nèi)核,負(fù)責(zé)最核心的meta data的集中管理,性能有較高的要求,設(shè)計(jì)初期就要求能夠支持cluster。項(xiàng)目使用Hibernate 3.2,針對(duì)開發(fā)過程中對(duì)于各種緩存的不同看法,撰寫了。重點(diǎn)在于澄清一些hibernate的緩存細(xì)節(jié),糾正一些錯(cuò)誤的緩存用法。

一、hibernate的二級(jí)緩存
    如果開啟了二級(jí)緩存,hibernate在執(zhí)行任何一次查詢的之后,都會(huì)把得到的結(jié)果集放到緩存中,緩存結(jié)構(gòu)可以看作是一個(gè)hash table,key是數(shù)據(jù)庫記錄的id,value是id對(duì)應(yīng)的pojo對(duì)象。當(dāng)用戶根據(jù)id查詢對(duì)象的時(shí)候(load、iterator方法),會(huì)首先在緩存中查找,如果沒有找到再發(fā)起數(shù)據(jù)庫查詢。但是如果使用hql發(fā)起查詢(find, query方法)則不會(huì)利用二級(jí)緩存,而是直接從數(shù)據(jù)庫獲得數(shù)據(jù),但是它會(huì)把得到的數(shù)據(jù)放到二級(jí)緩存?zhèn)溆。也就是說,基于hql的查詢,對(duì)二級(jí)緩存是只寫不讀的。

    針對(duì)二級(jí)緩存的工作原理,采用iterator取代list來提高二級(jí)緩存命中率的想法是不可行的。Iterator的工作方式是根據(jù)檢索條件從數(shù)據(jù)庫中選取所有目標(biāo)數(shù)據(jù)的id,然后用這些id一個(gè)一個(gè)的到二級(jí)緩存里面做檢索,如果找到就直接加載,找不到就向數(shù)據(jù)庫做查詢。因此假如iterator檢索100條數(shù)據(jù)的話,最好情況是100%全部命中,最壞情況是0%命中,執(zhí)行101條sql把所有數(shù)據(jù)選出來。而list雖然不利用緩存,但是它只會(huì)發(fā)起1條sql取得所有數(shù)據(jù)。在合理利用分頁查詢的情況下,list整體效率高于iterator。

    二級(jí)緩存的失效機(jī)制由hibernate控制,當(dāng)某條數(shù)據(jù)被修改之后,hibernate會(huì)根據(jù)它的id去做緩存失效操作。基于此機(jī)制,如果數(shù)據(jù)表不是被hibernate獨(dú)占(比如同時(shí)使用JDBC或者ado等),那么二級(jí)緩存無法得到有效控制。

    由于hibernate的緩存接口很靈活,cache provider可以方便的切換,因此支持cluster環(huán)境不是大問題,通過使用swarmcache、jboss cache等支持分布式的緩存方案,可以實(shí)現(xiàn)。但是問題在于:  分布式緩存本身成本偏高(比如使用同步復(fù)制模式的jboss cache)
2、 分布式環(huán)境通常對(duì)事務(wù)控制有較高要求,而目前的開源緩存方案對(duì)事務(wù)緩存(transaction cache)支持得不夠好。當(dāng)jta事務(wù)發(fā)生會(huì)滾,緩存的最后更新結(jié)果很難預(yù)料。這一點(diǎn)會(huì)帶來很大的部署成本,甚至得不償失。

結(jié)論:XXXX不應(yīng)把hibernate二級(jí)緩存作為優(yōu)化的主要手段,一般情況下建議不要使用。

原因  XXXX的DAO類大部分是從1.0升級(jí)過來,由于1.0采用的是hibernate 2.1,所以在批量刪除數(shù)據(jù)的時(shí)候采用了native sql的方式。雖然XXXX2.0已經(jīng)完全升級(jí)到hibernate 3.2,支持hibernate原生的批量刪改,但是由于hibernate批量操作的性能不如sql,而且為了兼容1.0的dao類,所以很多地方保留了sql操作。哪些數(shù)據(jù)表是單純被hibernate獨(dú)占無法統(tǒng)計(jì),而且隨著將來業(yè)務(wù)的發(fā)展可能會(huì)有很大變數(shù)。因此不宜采用二級(jí)緩存。
2、 針對(duì)系統(tǒng)業(yè)務(wù)來說,基于id檢索的二級(jí)緩存命中率極為有限,hql被大量采用,二級(jí)緩存對(duì)性能的提升很有限。
3、 hibernate 3.0在做批量修改、批量更新的時(shí)候,是不會(huì)同步更新二級(jí)緩存的,該問題在hibernate 3.2中是否仍然存在尚不確定。

轉(zhuǎn)帖于:軟件水平考試_考試吧
文章搜索
XXXX項(xiàng)目hibernate與應(yīng)用緩存方案總結(jié)網(wǎng)友評(píng)論網(wǎng)友評(píng)論
版權(quán)聲明 --------------------------------------------------------------------------------------
    如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請(qǐng)與我們聯(lián)系,我們將會(huì)及時(shí)處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請(qǐng)注明出處。
 gaoxiaoliang