MySQL使用Federate引擎实现操作本地表映射远程操作表

php中文网
发布: 2016-06-07 17:34:06
原创
1099人浏览过

考虑这样一个场景,存在多台agent系统(每台均拥有自己的数据库)各自做完操作后,将会触发各自数据库的存储过程进行复杂运算,各

考虑这样一个场景,存在多台agent系统(每台均拥有自己的数据库)各自做完操作后,将会触发各自数据库的存储过程进行复杂运算,各自完成后均需要向远程某master机器的数据库的表中擦入一条信息,以通知操作完成。初步设想有两个方案来实现。

  • 在agent系统里面通过java代码调用存储过程,直到存储过程执行完成后,再将执结束信息写入到Master系统的数据库中。
  • 通过为每一个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';

    BibiGPT-哔哔终结者
    BibiGPT-哔哔终结者

    B站视频总结器-一键总结 音视频内容

    BibiGPT-哔哔终结者 871
    查看详情 BibiGPT-哔哔终结者

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

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

    linux

    最佳 Windows 性能的顶级免费优化软件
    最佳 Windows 性能的顶级免费优化软件

    每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

    下载
    来源:php中文网
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    最新问题
    开源免费商场系统广告
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送
    PHP中文网APP
    随时随地碎片化学习

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号