paulwong

          分布式設(shè)計(jì)很簡單--guzz分布式切表功能正式發(fā)布(轉(zhuǎn))

          今天,經(jīng)過一個多月的線上運(yùn)行,我們很榮幸的發(fā)布guzz 1.2.9分布式切表功能。分布式切表是指將一張大表分切成N張小表,并將這些小表儲存到不同的數(shù)據(jù)庫(機(jī)器)中,從而實(shí)現(xiàn)數(shù)據(jù)的分散存儲和分散查詢。

          對于大型系統(tǒng)和數(shù)據(jù)規(guī)模較大的系統(tǒng),分布式切表提供了非常好的解決方案,有效的解決了大數(shù)據(jù)分散存儲、查詢、歸檔和維護(hù)等諸多的問題。但市面上流行的數(shù)據(jù)層框架,對于此特性幾乎無人涉及。guzz首次將這種技術(shù)做成了通用框架級別,更全面的提供“一站式數(shù)據(jù)層解決方案”。

          guzz 1.2.9 build20110209 更新介紹:

          分布式切表:

          guzz特性。

          分布式切表以guzz的Shadow Table為基礎(chǔ)。在Shadow Table的基礎(chǔ)上,通過配置完成,應(yīng)用不需要修改現(xiàn)有代碼即可完成小表的分布式存儲。
          具體請參看:http://code.google.com/p/guzz/wiki/TutorialVirtualDB?wl=zh-Hans

          至此,guzz已經(jīng)通過6個層面完成了全面的數(shù)據(jù)分切支持:


          數(shù)據(jù)表比較多,總體較大,將表分到不同的數(shù)據(jù)庫組中。
          第3章dbgroup:http://code.google.com/p/guzz/wiki/TutorialGuzzXml?wl=zh-Hans

          某些表太大,將大表分成N張小表。
          第15章ShadowTable:http://code.google.com/p/guzz/wiki/TutorialShadowTable?wl=zh-Hans

          業(yè)務(wù)比較特殊,每張小表可能包含自己的特性字段。
          第16章CustomTable:http://code.google.com/p/guzz/wiki/TutorialCustomTable?wl=zh-Hans

          分成小表后,小表太多,或在單庫中總量太大,將小表分散到不同的數(shù)據(jù)庫中。
          第17章VirtualDB:http://code.google.com/p/guzz/wiki/TutorialVirtualDB?wl=zh-Hans

          表中的某些字段太大,或者有特殊操作要求,將這些字段存到別的地方。
          第11章自定義加載屬性:http://code.google.com/p/guzz/wiki/TutorialLazyLoad?wl=zh-Hans

          訪問量的確太高,使用guzz原生支持的讀寫分離,部署更多讀數(shù)據(jù)庫。

          支持記錄SQL執(zhí)行時(shí)間:

          在打印執(zhí)行的SQL和SQL參數(shù)的同時(shí),通過 調(diào)試服務(wù)(DebugService) 兩個新的參數(shù)允許打印出sql執(zhí)行所花費(fèi)的時(shí)間,并且允許控制只打印執(zhí)行時(shí)間超過一定時(shí)長的sql語句。時(shí)間單位為納秒。

          具體請參看:http://code.google.com/p/guzz/wiki/AppendCoreService?wl=zh-Hans

          支持hbm.xml的package屬性:

          支持配置hbm.xml的類名時(shí),指定package。用于支持某些hibernate工具自動生成的配置文件。

          其他:

          1. 更改LogService為InsertQueueService;

          2. 修復(fù)了幾個bug。

          什么是guzz?

          guzz是一套用來解決ORM、多數(shù)據(jù)源管理、以及通用數(shù)據(jù)計(jì)算的數(shù)據(jù)層框架,為系統(tǒng)在數(shù)據(jù)層的設(shè)計(jì)提供一站式解決方案。guzz可以看作是 ibatis/hibernate的一大補(bǔ)充和延伸,并可以取代這2個東西。

          guzz主要功能與特點(diǎn):

          現(xiàn)代大規(guī)模系統(tǒng)設(shè)計(jì),技術(shù)上吸收了ibatis/hibernate的優(yōu)點(diǎn)
          對于大部分場景,支持像hibernate一樣的對象持久、映射和方便的增刪改查,提高開發(fā)效率
          對于復(fù)雜場景,支持像ibatis一樣,讓DBA參與SQL設(shè)計(jì)的復(fù)雜數(shù)據(jù)庫操作和優(yōu)化,以及SQL在線調(diào)試
          更簡潔、更好用、更容易控制的批操作接口
          支持在線加載與調(diào)試SQL。按照應(yīng)用策略,從文件/數(shù)據(jù)庫/Web Service等途徑,動態(tài)提取與使用SQL語句(Dynamic SQL)
          支持應(yīng)用程序使用大量的數(shù)據(jù)庫和主從讀寫分離
          支持?jǐn)?shù)據(jù)庫表在多組機(jī)器間水平分布(Shard),并自動維護(hù)多組機(jī)器之間的分布式事務(wù)
          支持1張表按照業(yè)務(wù)規(guī)則分切成多張小表(Shadow),并支持每張小表擁有自己特殊的屬性字段(Custom)
          支持1張大表分切后的小表,分布到不同的數(shù)據(jù)庫中(VirtualDB)
          支持超越范式的特殊關(guān)聯(lián)、非結(jié)構(gòu)化數(shù)據(jù)等異構(gòu)資源POJO模式的統(tǒng)一讀取
          支持組件化服務(wù)(SOA)和服務(wù)相互依賴,構(gòu)建企業(yè)/項(xiàng)目實(shí)施基礎(chǔ)平臺
          提供面向?qū)ο蟮臄?shù)據(jù)庫讀取標(biāo)簽(JSP Taglib),加快頁面展示層的快速變更、開發(fā)與部署
          支持配置管理服務(wù)器,可以使用一套軟件系統(tǒng)對所有應(yīng)用程序的配置進(jìn)行統(tǒng)一管理
          項(xiàng)目地址:http://code.google.com/p/guzz/
          文檔:http://code.google.com/p/guzz/wiki/WikiHomePage?tm=6
          下載:http://code.google.com/p/guzz/downloads/list

          posted on 2011-02-11 21:13 paulwong 閱讀(338) 評論(0)  編輯  收藏 所屬分類: J2EE

          主站蜘蛛池模板: 中山市| 孟津县| 高阳县| 屏东县| 施秉县| 顺昌县| 江源县| 隆昌县| 萍乡市| 宁国市| 封开县| 清新县| 文山县| 巴中市| 祁阳县| 深圳市| 安顺市| 永平县| 东安县| 宜城市| 满洲里市| 东乡| 新丰县| 石台县| 博湖县| 宣汉县| 肇源县| 安塞县| 淳安县| 彭山县| 房产| 崇左市| 天祝| 萍乡市| 鹤峰县| 志丹县| 武威市| 太原市| 海宁市| 旌德县| 耒阳市|