麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

Hibernate程序性能優化的考慮要點

2019-11-18 13:34:08
字體:
來源:轉載
供稿:網友

  本文依照HIBERNATE幫助文檔,一些網絡書籍及項目經驗整理而成,只提供要點和思路,具體做法可以留言探討,或是找一些更具體更有針對性的資料。

  初用HIBERNATE的人也許都碰到過性能問題,實現同一功能,用HIBERNATE與用JDBC性能相差十幾倍很正常,假如不及早調整,很可能影響整個項目的進度。

  大體上,對于HIBERNATE性能調優的主要考慮點如下:

  Ø 數據庫設計調整

  Ø HQL優化

  Ø API的正確使用(如根據不同的業務類型選用不同的集合及查詢API)

  Ø 主配置參數(日志,查詢緩存,fetch_size, batch_size等)

  Ø 映射文件優化(ID生成策略,二級緩存,延遲加載,關聯優化)

  Ø 一級緩存的治理

  Ø 針對二級緩存,還有許多特有的策略

  Ø 事務控制策略。

  1、 數據庫設計

  a) 降低關聯的復雜性

  b) 盡量不使用聯合主鍵

  c) ID的生成機制,不同的數據庫所提供的機制并不完全一樣

  d) 適當的冗余數據,不過分追求高范式

  2、 HQL優化

  HQL假如拋開它同HIBERNATE本身一些緩存機制的關聯,HQL的優化技巧同普通的SQL優化技巧一樣,可以很輕易在網上找到一些經驗之談。

  3、 主配置

  a) 查詢緩存,同下面講的緩存不太一樣,它是針對HQL語句的緩存,即完全一樣的語句再次執行時可以利用緩存數據。但是,查詢緩存在一個交易系統(數據變更頻繁,查詢條件相同的機率并不大)中可能會起反作用:它會白白耗費大量的系統資源但卻難以派上用場。

  b) fetch_size,同JDBC的相關參數作用類似,參數并不是越大越好,而應根據業務特征去設置

  c) batch_size同上。

  d) 生產系統中,切記要關掉SQL語句打印。

  4、 緩存

  a) 數據庫級緩存:這級緩存是最高效和安全的,但不同的數據庫可治理的層次并不一樣,比如,在Oracle中,可以在建表時指定將整個表置于緩存當中。

  b) session緩存:在一個HIBERNATE SESSION有效,這級緩存的可干預性不強,大多于HIBERNATE自動治理,但它提供清除緩存的方法,這在大批量增加/更新操作是有效的。比如,同時增加十萬條記錄,按常規方式進行,很可能會發現OutofMemeroy的異常,這時可能需要手動清除這一級緩存:Session.evict以及Session.clear

  c) 應用緩存:在一個SESSIONFACTORY中有效,因此也是優化的重中之重,因此,各類策略也考慮的較多,在將數據放入這一級緩存之前,需要考慮一些前提條件:

  i. 數據不會被第三方修改(比如,是否有另一個應用也在修改這些數據?)

  ii. 數據不會太大

  iii. 數據不會頻繁更新(否則使用CACHE可能適得其反)

  iv. 數據會被頻繁查詢

  v. 數據不是要害數據(如涉及錢,安全等方面的問題)。

  緩存有幾種形式,可以在映射文件中配置:read-only(只讀,適用于很少變更的靜態數據/歷史數據),nonstrict-read-write,read-write(比較普遍的形式,效率一般),transactional(JTA中,且支持的緩存產品較少)

  d) 分布式緩存:同c)的配置一樣,只是緩存產品的選用不同,在目前的HIBERNATE中可供選擇的不多,oscache, jboss cache,目前的大多數項目,對它們的用于集群的使用(非凡是要害交易系統)都持保守態度。在集群環境中,只利用數據庫級的緩存是最安全的。

  5、 延遲加載

  a) 實體延遲加載:通過使用動態代理實現

  b) 集合延遲加載:通過實現自有的SET/LIST,HIBERNATE提供了這方面的支持

  c) 屬性延遲加載:

  6、 方法選用

  a) 完成同樣一件事,HIBERNATE提供了可供選擇的一些方式,但具體使用什么方式,可能用性能/代碼都會有影響。顯示,一次返回十萬條記錄(List/Set/Bag/Map等)進行處理,很可能導致內存不夠的問題,而假如用基于游標(ScrollableResults)或Iterator的結果集,則不存在這樣的問題。

  b) Session的load/get方法,前者會使用二級緩存,而后者則不使用。

  c) Query和list/iterator,假如去仔細研究一下它們,你可能會發現很多有意思的情況,二者主要區別(假如使用了SPRing,在HibernateTemplate中對應find,iterator方法):

  i. list只能利用查詢緩存(但在交易系統中查詢緩存作用不大),無法利用二級緩存中的單個實體,但list查出的對象會寫入二級緩存,但它一般只生成較少的執行SQL語句,很多情況就是一條(無關聯)。

  ii. iterator則可以利用二級緩存,對于一條查詢語句,它會先從數據庫中找出所有符合條件的記錄的ID,再通過ID去緩存找,對于緩存中沒有的記錄,再構造語句從數據庫中查出,因此很輕易知道,假如緩存中沒有任何符合條件的記錄,使用iterator會產生N+1條SQL語句(N為符合條件的記錄數)

  iii. 通過iterator,配合緩存治理API,在海量數據查詢中可以很好的解決內存問題,如:

  while(it.hasNext()){

  YouObject object = (YouObject)it.next();



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 成人一级片毛片 | 国产免费福利视频 | 精品xxxx户外露出视频 | 国产成人高潮免费观看精品 | 日本在线精品视频 | 久久爽精品区穿丝袜 | 亚洲一级簧片 | 国产精品免费看 | 日韩色视频在线观看 | 99视频有精品视频高清 | 一区二区三区视频播放 | 欧美va亚洲 | 国产一区二区三区欧美 | 毛片视频观看 | 国产精品av久久久久久网址 | 夜夜看 | 午夜精品久久久久久中宇 | 欧美日韩高清一区二区三区 | 国产精品久久久久久久久久三级 | 欧美成人精品欧美一级乱黄 | 91精品国产综合久久久动漫日韩 | 九九色网站| av影院在线播放 | 国产色视频免费 | 999精品久久久| 亚洲人成网站在e线播放 | 在线看免电影网站 | 日本在线观看一区二区 | 国产自在自线午夜精品视频在 | 粉嫩av一区二区三区四区在线观看 | 日韩99| 久久久久久久亚洲精品 | av在线播放地址 | 国产精品一区久久久久 | 国产盼盼私拍福利视频99 | 国产在线a | 视频一区二区三区在线播放 | 三级国产三级在线 | 欧美性视频一区二区 | 免费一区在线 | 91 免费视频 |