自己寫的一個cache小組件

          Cache作為提高性能的有效手段可以說是無處不在的。CPU有一級緩存,二級緩存;數據庫有自己的數據緩存;內存實質上就是硬盤的緩存。。。。。。而程序中的緩存也能夠有效的減少與存儲設備的交互,增加應用的并發能力。

          我通過在實際項目中自行設計和使用cache,逐漸提高了系統的并發能力,但同時也感覺到了很多的不足:

          1.       因為是在原有系統基礎上優化,cache的處理沒有統一的規劃,而是頭痛醫頭,腳痛醫腳。cache分散在系統各個模塊,很難想起哪些模塊使用了cache

          2.       cache的實現各種各樣,有的是單例、有的是static對象,而cache對象與數據庫的交互也是直接硬編碼在原有系統中,難于維護

          3.       cache的參數如刷新間隔。。。。。。未使用配置文件,而是直接定義在cache的類文件中,對配置的更改就需要更新整個類,進而影響系統的運行

          4.       缺少對cache的監控機制和log機制,出現問題很難去跟蹤和解決。

          經過一段時間具體項目的洗禮,對java也有了進一步的認識,我也可以有能力來解決一直困擾心中的cache的這些問題了。想法很簡單,就是能夠通過單一的配置文件,對系統中的所有cache進行統一的管理,各個cache所在的模塊,和cache的配置參數,都能夠一目了然。而對配置文件的重載功能也是我要考慮的問題,希望對某些cache的配置的更改能夠對其它cache無影響,同時這些更改也能在不影響應用運行狀態的情況下進行。當然既然是統一管理,就需要做到接口的統一。我定義了CacheCachePersistence兩個接口,然后不同的cache可以提供不同的實現,實現類需要在配置文件中指定,同時系統提供默認的實現,以滿足簡單的應用。想了就要開始做,我也沒想一開始就做出象OSCacheJbossCache那樣通用的cache來,也許經過不斷的交流,不斷的完善最終可以做到。經過簡單的設計,我就開始寫代碼了,就我一個人,也算是XP編程了,呵呵!cache的配置參數,我根據項目經驗想到了幾個,可能還可以有,但目前我不知道,需要在更多的項目應用中去發現,具體可以看我的包中的cache.xml文件,有對配置項的具體說明。

          從開始開發到最后寫完測試類,也就不到一個星期的時間(上班的空余時間和加班寫),當中也進行了幾次重構。總的來說,還算滿意,這也算俺的第一個開源項目啊,呵呵!

          具體如何使用,很簡單,你有興趣可以實現Cache接口,我內置了基于HashMapCache,應該能滿足大部分應用的需要。CachePersistence就是你的對象與存儲設備交互的實現了,你一般需要實現這一接口,然后配置在配置文件中。然后通過CacheFactory得到Cache,通過Cache接口使用對象。對Cache的操作你可以當成一個Map來使用,由容器來自動處理何時與存儲設備的交互,你只要配置好就ok了。另外可以參考src中的test包,里面是我對Cache的功能測試代碼,也能作為使用cache的實例的。

          說了這么多,大家如果有興趣,可下載我的全部文件,里面包括jarsrclibjavadoc還有配置文件,點擊這里http://www.aygfsteel.com/Files/pesome/pcache.zip。更歡迎大家在實際的項目中使用我的cache,如果有任何問題都可以跟我聯系,mailto:pesome@163.com。謝謝!

          posted on 2005-09-06 15:38 pesome 閱讀(2230) 評論(6)  編輯  收藏 所屬分類: 開源軟件

          評論

          # re: 自己寫的一個cache小組件 2005-09-06 17:48 margiex

          Resource not found  回復  更多評論   

          # re: 自己寫的一個cache小組件 2005-09-07 09:19 pesome

          鏈接開始有點錯誤,我已經更改!謝謝!  回復  更多評論   

          # re: 自己寫的一個cache小組件 2005-09-08 11:13 Xuefeng

          好像你的算法是整個Cache Pool都全部刷新,最好根據LRU算法

          另外Week引用好像可以適用于Cache  回復  更多評論   

          # re: 自己寫的一個cache小組件 2005-09-08 12:27 pesome

          呵呵,如果配置文件更改,我會刷新相應的cache。你所說的LRU算法應該是cache有大小限制,在已滿狀態下增加新的對象的替換算法,這個我還沒實現,呵呵!目前沒有大小限制。“Week引用好像可以適用于Cache ”,有點不明白,能說的更詳細些嗎?謝謝  回復  更多評論   

          # re: 自己寫的一個cache小組件 2005-09-12 15:26 Xuefeng

          cache的實現是很復雜的,如果不考慮大小限制肯定會內存溢出,定期刷新的cache還好一點,要實現讀寫同步的通用cache基本上特別困難,現在比較好的cache框架就是oscache  回復  更多評論   

          # re: 自己寫的一個cache小組件 2009-12-28 16:29 ll

          頂  回復  更多評論   

          <2005年9月>
          28293031123
          45678910
          11121314151617
          18192021222324
          2526272829301
          2345678

          導航

          統計

          公告

          主要記錄作者在學習java中的每一步足跡。除非特別說明,所有文章均為本blog作者原創,如需轉載請注明出處和原作者,如用于商業目的,需跟作者本人聯系。
          歡迎大家訪問:

          常用鏈接

          留言簿(16)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          相冊

          收藏夾

          java技術

          人間百態

          朋友們的blog

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 天津市| 贞丰县| 乌什县| 汕头市| 拜城县| 安岳县| 水富县| 尚志市| 甘肃省| 阳城县| 永顺县| 韶山市| 玛沁县| 阿瓦提县| 上饶县| 建宁县| 崇义县| 新巴尔虎左旗| 丽水市| 绥棱县| 秦皇岛市| 高碑店市| 吴旗县| 固始县| 珲春市| 密云县| 平凉市| 沾化县| 嘉定区| 稻城县| 深泽县| 昌宁县| 伊春市| 新龙县| 张家口市| 巨野县| 中山市| 汉沽区| 绥棱县| 青浦区| 亳州市|