MySQL使用Federate引擎实现操作本地表映射远程操作表
考虑这样一个场景,存在多台agent系统(每台均拥有自己的数据库)各自做完操作后,将会触发各自数据库的存储过程进行复杂运算,各
考虑这样一个场景,存在多台agent系统(每台均拥有自己的数据库)各自做完操作后,将会触发各自数据库的存储过程进行复杂运算,各自完成后均需要向远程某Master机器的数据库的表中擦入一条信息,以通知操作完成。初步设想有两个方案来实现。
因为在实际项目中,第一种方式的会因为存储过程的运行时间过长(半个小时甚至更久),会导致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:需要注意的是,此种方式不适合大数据量的同步操作。