跳到主要內容

SEQUOIA初體驗(一)

1.下載SEQUOIAhttp://sequoia.continuent.org/HomePage),有幾個版本可以下載bin-install的版本。

2. 安裝步驟如圖。










3. 安裝後先將安裝後的SEQUOIA路徑中config資料夾的sequencer.xml複製到driver資料夾(因為有個case需要使用到JGroupAPI不過似乎該APIIP為寫死的)。


4. 複製所需的資料來源的JDBC Driverdriver資料夾,例如MSSQLjtds.jar等等


5. 先透過該API提供的demo進行測試

5.1執行demo資料夾中的demo-raidb1.bat啟動HSQLDB,分別啟動900190029003 portHSQLDBnetstat -na

5.2config\controller資料夾中controller.xml換成controller-raidb1.xml,再執行bin\controller.bat

5.3執行bin\console.bat,若是有出現localhost:1090>表示相關設定無誤。可以試試幾個指令操作看看

admin myDB,選擇要操作的VirtualDatabase

輸入使用者(admin)及密碼(無)

show backend *,顯示目前所有的backend

initialize localhost1backend名稱) force

enable *,啟動全部的backend※要先要initialize backend後方可enable

6. 進行研究RAIDb-0模式(同一資料來源)(Full partitioning of database

l 同一個資料來源(MSSQL),兩個資料庫(database1及database2)設定檔如下

l 直接執行bin\controller.bat(請修改controller.xml的對應)

l 啟動console.bat進行確認

admin myDB,選擇VirtualDatabase

admin,使用者

無,密碼

show backend *,確認是否都已經啟動了

quit,登出

sql client jdbc:sequoia://127.0.0.1:25322/myDB,連接virtualdatabase

user,使用者

無,密碼

select top 1 * from log1,簡易SQL測試(For database1

select top 1 * from log2,簡易SQL測試(For database2

常會出現Java Heap不夠的問題,需要進行最佳化

2. 進行研究RAIDb-0模式(不同資料來源)(Full partitioning of database

l 不同資料來源(MSSQLHSQLDB),兩個資料庫(database1及database2)設定檔如下

l 先啟動demo\demo-raidb1.bat

l 執行bin\controller.bat(請修改controller.xml的對應)

l 啟動console.bat進行確認

admin myDB,選擇VirtualDatabase

admin,使用者

無,密碼

show backend *,確認是否都已經啟動了

quit,登出

sql client jdbc:sequoia://127.0.0.1:25322/myDB,連接virtualdatabase

user,使用者

無,密碼

select top 1 * from log1,簡易SQL測試(For database1

select * from product,簡易SQL測試(For database2

7. 進行研究RAIDb-1模式(同一資料來源)(Full replication

l 同一個資料來源(MSSQL),兩個資料庫(database1及database2)設定檔如下

l 先啟動demo\demo-raidb1.bat(因為這裡會使用到RecoverLog

l 直接執行bin\controller.bat(請修改controller.xml的對應)

l 啟動console.bat進行確認

admin myDB,選擇VirtualDatabase

admin,使用者

無,密碼

show backend *,確認是否都已經啟動了

quit,登出

sql client jdbc:sequoia://127.0.0.1:25322/myDB,連接virtualdatabase

user,使用者

無,密碼

Create table test1(id bigint not null,name varchar not null),會看到database1及database2資料庫均會有該資料表,

需要進階透過程式或JMeter測試效能及shutdown database測試

這裡設定主要為localhost1也就是使用database1為主要,也可透過url的參數設定如亂數或是RoundRobin等等方式。

總結

api提供的一透通性的介面(與各資料來源或是資料庫),應用程式或系統可透過單一連線方式(sequoia)同時取得不同資料來源的資料,或透過本api可進行資料庫的Cluster可不用透過昂貴的軟體進行(但是效能需要測試),另外因為採用類似磁碟陣列方式進行的資料庫陣列有多種模式可以進行,並提供所謂的Hot swapping可以動態增加資料來源(backend),而且使用Java撰寫所以安裝在不同的作業系統上,又因為為OpenSource所以其成本較低。待續(sequoia進階使用)


p.s因為xml貼上怪怪的需要設定檔的再發個email給我囉!

留言

這個網誌中的熱門文章

IReport中的條碼類別BcImage

最近有一個繳費單的專案,需要列印條碼,因為IReport本身就有提供列印條碼的功能,所以就用IReport設計繳費單然後再用Jasperreport API寫批次程式去產生PDF,資料量大概3000多筆(頁)拆成幾個檔案,可是就發生了一個問題居然發生部分繳費單的條碼有問題,看了一下程式研判是Race Condition因為程式採用的是多執行緒,若是依序個別產生是不會有問題,但是同時執行的時候就會亂掉,而且都錯在條碼,令我覺得很奇怪,後來我查了一下發現it.businesslogic.ireport.barcode.BcImage 類別我猜是這裡的問題,就先加上synchronized重新編譯在去執行,嘿嘿條碼就對了,做了一下壓測也正常,程式碼如下,不過這樣事不是對了可能還要仔細查查看。 public class BcImage { private static net.sourceforge.barbecue.Barcode bc = null; public synchronized static net.sourceforge.barbecue.Barcode getBarcode() { return bc; } public synchronized static BufferedImage getBarcodeImage(int type, Object aText, boolean showText, boolean checkSum) { return getBarcodeImage(type, aText, showText, checkSum,"",0,0); } public synchronized static BufferedImage getBarcodeImage(int type, Object aText, boolean showText, boolean checkSum, String applicationIdentifier, int width, int height) { // 2of7, 3of9, Bookland, Codabar, Code128,...

Ext-Js Grid + DWR

Ext-Js中有Grid的sample,想說試試看加上DWR的效果如何?感覺上還不錯,以下是我參考Ext-Js附的grid array sample,加上DWR調整一下的code,我想可能還要加上資料在Loading的效果會比較好。 array-grid.js Ext.onReady(function(){ Ext.state.Manager.setProvider(new Ext.state.CookieProvider()); // example of custom renderer function function change(val){ if(val > 0){ return ' ' + val + ' '; }else if(val ' + val + ' '; } return val; } // example of custom renderer function function pctChange(val){ if(val > 0){ return ' ' + val + '% '; }else if(val ' + val + '% '; } return val; } //要設定Dwr傳回的Map的對應格式 var recordType = Ext.data.Record.create( [ {name:"reportid",mapping:"reportid",type:"string"}, {name:"reportName",mapping:"reportName",type:"string"} ] ); var myReader = new Ext.data.JsonReader( { totalProperty:"totalSize", root:"data" },recordType ); // create the data store //這裡是很重要的,這裡還可以加上listener等等的屬性喔 var store = new Ext.da...

IBM MQ 5.3 Server安裝在RHEL 4

最近在整理一些文件,整理出來一些IBM MQ相關的文件,因為相關專案都是自己來開發,所以有些文件我個人覺得還滿有價值,其實安裝IBM MQ Server在RHEL還滿簡單的,只要注意幾個關鍵點,還有就是不要用光碟中的JRE就順多了,這個問題我有問過IBM,得到的答案是建議安裝Sun的JRE會比較好,真得讓我......步驟如下 1.先安裝RHEL 4 這裡就省略不說了 2.於Sun網站下載For Linux J2SDK1.4.2以上版本,建議下載.bin版本。進行安裝: 2.1 執行./xxx.bin,會自動解壓縮出xxx.rpm 2.2 rpm -ivh xxx.rpm 2.3 會詢問安裝目錄,請依需求安裝這裡為預設。 2.4 安裝完成後,調整/etc/profile檔案,設定JAVA_HOME指定到J2SDK安裝的目錄,並將J2SDK的bin目錄加入path中。 3.安裝IBM MQ 3.1安裝MQ需先進行License安裝,否則安裝程式不會執行,因光碟中提供的mqlicense.sh,IBM已有提供更新版,故建議下載IBM網站提供的update版本進行安裝。 ※mqlicense.sh一樣也要設定權限,chmod 755 mqlicense.sh 3.2安裝完後的license會在/tmp下建立一license的目錄所以要注意/tmp需要開777的權限Chmod 777 –R /tmp 3.3先設定變數(可以設定/etc/profile) Export LD_ASSUME_KERNEL=2.4.19 Export RPM_FORCE_NPTL=1 3.4依據下列順序安裝: rpm -i MQSeriesRuntime-5.3.0-1.i386.rpm rpm -i MQSeriesSDK-5.3.0-1.i386.rpm rpm -i MQSeriesServer-5.3.0-1.i386.rpm 3.5安裝後需要進行下列環境變數設定方可使用MQ ln –sf /opt/mqm/lib/xxx/* /opt/m...