码迷,mamicode.com
首页 > 数据库 > 详细

MySQL使用Federate引擎

时间:2017-05-04 11:03:15      阅读:285      评论:0      收藏:0      [点我收藏+]

标签:开启   用户名   str   password   nec   ora   new   roo   .com   

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:123123@ServerA: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:password@202.59.232.211:3306/testdb/tb_projects_tests‘;

注意connection语句的设置,需要远程Master数据库的用户名,密码以及映射表的相应信息,中然后在每一个存储过程执行完成后对本地的projects执行一条insert语句即可。

PS:需要注意的是,此种方式不适合大数据量的同步操作。

 

 

 

MySQL使用Federate引擎

标签:开启   用户名   str   password   nec   ora   new   roo   .com   

原文地址:http://www.cnblogs.com/runs/p/Federate.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!