文档章节

用mysql的federated数据引擎和触发器实现远程服务器表数据同步

史帝文
 史帝文
发布于 2017/08/14 22:31
字数 531
阅读 35
收藏 0

1,检查mysql是否支持federated数据引擎,若不支持可能需要修改mysql配置文件;
 -- 查看开启的储存引擎
 
   SHOW ENGINES;
  
   -- 若没有federated 引擎需要配置my.ini 文件。
   --在[mysqld]后面直接加federated,并且注释掉skip-federated(前面加#)

2,检查从库的权限及登录用户,密码能否使用。

3,在从库121.12.170.b 上创建一个表,这个最好在148.56.106.2的服务器使用远程mysql -uroot -h121.12.170.b登录来操作。

 CREATE TABLE `fed_user2` (  
  `uid` BIGINT(20) NOT NULL AUTO_INCREMENT,  
  `user_name` CHAR(17) DEFAULT NULL COMMENT '用户名',  
  `user_pwd` CHAR(32) DEFAULT NULL COMMENT '密码',  
  PRIMARY KEY (`uid`)  
) ENGINE=FEDERATED


4,在主库148.56.106.2 创建一个表

 CREATE TABLE `fed_user` (  
  `uid` BIGINT(20) NOT NULL AUTO_INCREMENT,  
  `user_name` CHAR(17) DEFAULT NULL COMMENT '用户名',  
  `user_pwd` CHAR(32) DEFAULT NULL COMMENT '密码',  
  PRIMARY KEY (`uid`) 
) ENGINE=FEDERATED CONNECTION='mysql://root:myroot@121.12.170.b:3306/maxhomSport/fed_user2';   


mysql://root:myroot@121.12.170.b:3306/maxhomSport/fed_user2 就是在148.56.106.2登录到121.12.170.b的3306端上的maxhomSport数据库的fed_user2表。

5,测试在148.56.106.2的服务器上的表fed_user上插入数据
INSERT INTO `maxhom_kaiyuan`.`fed_user` (`user_name`, `user_pwd`) VALUES ('aaaa', '111'); 
INSERT INTO `maxhom_kaiyuan`.`fed_user` (`user_name`, `user_pwd`) VALUES ('a2', '222'); 
INSERT INTO `maxhom_kaiyuan`.`fed_user` (`user_name`, `user_pwd`) VALUES ('a3', '3333'); 
刷新148.56.106.2的表,查看存盘是否成功。如果成功,在检查远程121服务器端的数据表fed_user2几个号否成功。
   uid  user_name  user_pwd  
------  ---------  ----------
     1  aaaa       111       
     2  a2         222       
     3  a3         3333      
 
按以上操作,检查是成功的。

6,反操作,向121服务器的表插入数据,检查148.56.106.2表的变动。 
在网络正常的情况,2边mysql都是start的情况下
148.56.106.2表有变化,121的表也有变化。2边的数据同步了
这个变化我有点想不通。
148.56.106.2是局域网,从121向148.56.106.2是ping不通的。但是在操作中121可以逆向写sql数据,很神奇。

7,断网人为制造故障测试 ,停121.12.170.b mysql下的服务器情况,向148.56.106.2的fed_user表插入数据。结果显示:
“Got error 10000 'Error on remote system: 2003: Can't connect to MySQL server on '121.12.170.b' (111)' from FEDERATED” 
结果为二边都不能插入数据。

       
       


 

© 著作权归作者所有

共有 人打赏支持
史帝文
粉丝 6
博文 56
码字总数 22088
作品 0
武汉
后端工程师
私信 提问
MySQL federated引擎 --- 实现类似oracle dblink功能

1.查看是否安装了federated引擎 show engines; 2.开启federated引擎 windows下在my.ini中加入federated,即可开启; linux中,需要编译时加入选项,再在my.ini中加入federated,方可开启. 3.建...

shaohan
2014/03/21
0
0
MySQL FEDERATED引擎使用示例, 类似Oracle DBLINK.

1 引擎说明 本地MySQL数据库要访问远程MySQL数据库的表中的数据, 必须通过FEDERATED存储引擎来实现. 有点类似Oracle中的 数据库链接(DBLINK). 要允许这个存储引擎, 当构建MySQL时使用--with-...

SANSOM
2013/08/21
0
4
MySQL远程表访问设置

使用MySQL FEDERATED存储引擎,没有对表的本地数据文件(比如,没有.MYD文件)。取而代之地,一个远程数据库存储那些正常地应该在表中的数据。这使得MySQL客户端API来读,删除,更新和插入数...

鉴客
2012/04/26
4.2K
0
MySQL的FEDERATED引擎实现类Oracle的DBlink

随着业务的复杂度不断的增加、数据库不断的切分,在分布式系统中往往一台或几台数据库并不能满足我们的需求,所以常常需要多台同时时用,而在平时需要通过其它服务器的数据库获取信息最为方便...

往事_Jim_遗
2017/12/04
0
0
使用mysql federated引擎构建MySQL分布式数据库访问层(转)

使用mysql federated 引擎构建 MySQL 分布式数据库访问层 前言:随着应用复杂度的增加,数据库不断细化切分,导致应用程序中数据库应用就得复杂,凌乱。绝大部分程序人员可能都遇到这种情况,...

lilclimate
2013/08/28
0
0

没有更多内容

加载失败,请刷新页面

加载更多

颜色模型与颜色应用---光的特性

电磁频谱 颜色的心理学特征

中国龙-扬科
18分钟前
2
0
android音频及强噪相关

Android AudioRecord和AudioTrack介绍(Android音频收集和播放 麦克风降噪) https://blog.csdn.net/tanningzhong/article/details/72844559 音频采集(AudioRecorder) https://www.jianshu.......

whoisliang
25分钟前
2
0
redis-持久化

RDB rdb持久化是把当前进程数据生成快照保存到磁盘的过程。触发RDB持久化过程分为手动触发和自动触发。 触发机制 bgsave执行流程 rdb优缺点 AOF 记录每次写命令,重启时再重新执行aof文件中的...

grace_233
30分钟前
3
0
电话激活Windows 中文操作系统步骤

已购买微软MAK批量授权,系统又在企业内网中,无法通过连接Internet进行激活,还可以通过电话完成激活。 前期准备 请提前准备好产品密钥,Product Key格式如下:XXXXX-XXXXX-XXXXX-XXXXX-XXX...

tonyfox
32分钟前
4
0
Apache用户认证,域名跳转,访问日志

Apache用户认证 当设置了用户认证后,用户访问网站时,需要输入用户名和密码才能访问。 可以全局设置,也可以为某几个虚拟主机单独配置。 下面以全局配置进行操作示例。 编辑httpd.conf进行配...

野雪球
36分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部