1. 程式人生 > >MySQL使用Federate引擎

MySQL使用Federate引擎

ted top varchar linux中 tro 存儲 nes def 映射

1. 查看Mysql數據庫是否已經安裝Federate引擎

技術分享

  FEDERATES Support NO表示未開啟。

2.開啟federated引擎

  windows下在my.ini中加入federated,即可開啟;

  linux中,需要編譯時加入選項,再在my.ini中加入federated,方可開啟.

  3.建立遠程數據表鏈接

  假如:在ServerA上有一個數據庫dbtestA,在ServerB上有數據庫dbtestB,要在ServerB的數據庫dbtestB上建立 ServerA的數據庫dbtestA上的表的數據表鏈接remote_tabletestA,語句如下:

以下是代碼片段:

  create table remote_tabletestA ... ... engine=federated connection = ‘MySQL://root:[email protected]
/* */:3306/dbtestA/tabletestA‘;

  4.使用遠程數據表鏈接

  如上例,直接在ServerB的數據庫dbtestB上對表remote_tabletestA進行操作,即是操作ServerA上數據庫dbtestA的表tabletestA.

  5.MySQL使用Federate引擎實現操作本地表映射遠程操作表

  

考慮這樣一個場景,存在多臺agent系統(每臺均擁有自己的數據庫)各自做完操作後,將會觸發各自數據庫的存儲過程進行復雜運算,各自完成後均需要向遠程某Master機器的數據庫的表中擦入一條信息,以通知操作完成。初步設想有兩個方案來實現。

  1. 在agent系統裏面通過java代碼調用存儲過程,直到存儲過程執行完成後,再將執結束信息寫入到Master系統的數據庫中。
  2. 通過為每一個agent系統中的數據庫建立一個遠程映射表,從而實現agent系統存儲過程執行完成後,通過存儲過程再將信息寫入本地的映射表中,由mysql自動同步數據到Master上。(此處也凸顯出mysql一個短板,本地存儲過程不能調用遠程數據庫的存儲過程,不能操作遠程數據庫的表,貌似Oracle,sqlserver等都可以,不然就不用這麽麻煩了╮(╯▽╰)╭)

因為在實際項目中,第一種方式的會因為存儲過程的運行時間過長(半個小時甚至更久),會導致agent系統的性能有影響,迫於無賴才使用第二種方案。

首先需確保已經打開federated引擎,可通過show engines命令查看是否安裝。然後具體步驟如下:

首先在Master機器上建立projects表,我們只需要將每個agent數據庫中建立映射表projects

CREATE TABLE `projects` (
`project_id` INT(11) NOT NULL AUTO_INCREMENT,
`project_code` VARCHAR(50) NOT NULL,
`test_code` VARCHAR(50) NOT NULL,
`create_time` BIGINT(11) NULL DEFAULT NULL,
`result` VARCHAR(255) NULL DEFAULT NULL,
`ts` BIGINT(11) NOT NULL,
PRIMARY KEY (`id`)
)
COLLATE=‘utf8_general_ci‘
ENGINE=FEDERATED
CONNECTION=‘mysql://user:[email protected]:3306/testdb/tb_projects_tests‘;

註意connection語句的設置,需要遠程Master數據庫的用戶名,密碼以及映射表的相應信息,中然後在每一個存儲過程執行完成後對本地的projects執行一條insert語句即可。

PS:需要註意的是,此種方式不適合大數據量的同步操作。

 

MySQL使用Federate引擎