记录一下这次做的双向同步及环形同步吧,都是最简单的实现;

具体实现之前,先说些与之有关的内容吧,大部分内容都是网上的,操作步骤则是亲自测试之后记录下的;

一. 数据同步的几种方式:

1. 触发器,在数据库中建立增删改的触发器,每当数据库有变化,就会激活触发器,进而执行相应的操作,缺点是性能问题;

2. 时间戳,即在要同步的表里增加一个字段,当数据变化后,这个字段会发生相应的变化,然后根据这个字段的值来进行同步,可以是日期类型,记录当前的时间,缺点是有些延时,并且是每个表都要有这个字段。这中间还会涉及到逻辑删除;

3. 日志记录,通过分析数据库的日志,来获取数据库中变化的数据,缺点有些延时,并且对于没有提供日志分析接口的数据库,开发难度较大;

二. 数据库双向同步的实现

系统:windows 7旗舰版

数据库:MySQL Server 5.0

主机A的IP:192.168.75.129     主机B的IP:192.168.75.130

1. 首先要保证两台主机间能的网络通信是正常的,可以ping一下或Telnet一下;

2. 添加同步帐号:

grant replication slave,replication client on *.* to backup@'192.168.75.129' identified by '123456';

也可设置为局域网内访问,即IP为192.168.75.%。

在主机A和B上分别执行了添加帐号之后,先测试一下能否正常连接,如在B上测试:

mysql -u backup -p -h192.168.75.129 -P3306

如果不能访问,多半是账户backup的权限不够,修改权限即可;

在A中重新对backup账户grant一下,如果grant了几次都不行,那就给所有的权限,当然,只是为了测试;

grant all privileges on *.* to ‘backup’@’%’ identified by ‘123456’;

3. 停掉A和B的MySQL服务,然后对A和B的my.ini进行配置,A和B的server-id不一样;

server-id = 1      #MySQL服务器标志,必须唯一
log-bin=mysql-bin #二进制日志文件的位置和命名
log-slave-updates=1 #事件自动更新到日志中
sync_binlog=1 #日志文件同步到磁盘上
replicate_do_db=test #要同步的数据库名称

4. 启动各自的MySQL服务,进行动态的Change master配置,先对B进行配置:

change master to master_host='192.168.75.129',
master_user='backup',
master_password='123456',
master_log_file='mysql-bin.000001',
master_log_pos=0;

至于master_log_file和master_log_pos可以使用show master status来查看的;

然后对A执行相同的操作,注意master_host,如果报错,先slave stop,在操作,再slave start即可;

5. 使用show slave status\G来查看同步是否正确执行;

show slave status\G

如果Slave_IO_Running、Slave_SQL_Running都为YES,则表明配置已经成功,下一步可以准备测试了;

6. 可以进行简单的create, alter ,update, insert ,delete测试了;

三. 环形同步

系统:windows 7旗舰版

数据库:MySQL Server 5.0

主机A的IP:192.168.75.129     主机B的IP:192.168.75.130   主机C的IP:192.168.75.131

1. 采用环形操作,即A是B的主服务器,B是C的主服务器,C又是A的主服务器,依次类推组成一个环状结构。这样ABC三台服务器,在任意一台执行数据操作,数据均会同步其他服务器上。

2. 分别配置A、B、 C的my.ini,在[mysqld]下添加如下配置内容:

server-id = 1
log-bin=mysql-bin
log-slave-updates=1
slave-skip-errors=all
replicate_do_db=test

其中需注意A、B、C的server-id是不同的;

3. 配置完成后,重启各主机的服务;

4. 对主机A添加专门用于同步的账户,操作过程和双向同步类似;

GRANT REPLICATION SLAVE ON *.* TO 'backup'@'192.168.75.130:3306' IDENTIFIED BY '123456';

5. 然后对B也进行同样操作,但@的是C的地址,并且根据A的show master status的日志文件和偏移量,进行如下操作:

slave stop;

CHANGE MASTER TO MASTER_HOST='192.168.75.129',
MASTER_USER='backup',
MASTER_PASSWORD='123456',
MASTER_PORT=3309,
MASTER_LOG_FILE='mysql-bin.000001', //A的日志文件
MASTER_LOG_POS=98; //A的偏移量 slave start;

需注意的是端口号,因为我的端口号修改为了3309;

6. 对C进行同样操作,@的是A的地址,并且根据B的show master status的日志文件和偏移量,进行配置:

其中master_host是B的IP地址;

然后对A进行操作,根据C的show master status,进行同样的配置,注意master_host;

7.全部重启服务,分别看下show slave status\G,如果是YES,就没问题了:

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

8.可以测试了;

总结:

1. 实现过程中,遇到最多的问题应该就是账户的权限不足,导致ping不通的问题了;

2. 这次双向同步和环形同步实现的是最简单的,好多问题都没有考虑,如权限问题,ID冲突的问题,环形同步的稳定性问题,即如果一个节点出了问题,别的节点都会收到影响;

3. 参考网址:MySQL环形同步和测试

Windows下MySQL双向同步及环形同步的实现的更多相关文章

  1. windows下mysql的数据主主同步

    mysql主主备份: 保证各服务器上的数据库中的数据一致,因此需要开启数据库同步机制.由于是一整套系统,并且系统内含数据库.由于任何一台服务器都有可能被选中,因此要让所有的数据库上的数据都是最新的,任 ...

  2. Windows 下目录及文件向Linux同步

    本文解决的是Windows 下目录及文件向Linux同步的问题,Windows向 Windows同步的请参考:http://www.idcfree.com/article-852-1.html 环境介 ...

  3. MySQL 5.7 Command Line Client输入密码后闪退和windows下mysql忘记root密码的解决办法

    MySQL 5.7 Command Line Client输入密码后闪退的问题: 问题分析: 1.查看mysql command line client默认执行的一些参数.方法:开始->所有程序 ...

  4. coreseek实战(二):windows下mysql数据源部分配置说明

    coreseek实战(二):windows下mysql数据源部分配置说明 关于coreseek在windows使用mysql数据源的配置,以及中文分词的详细说明,请参考官方文档: mysql数据源配置 ...

  5. Windows下mysql自动备份的最佳方案

    网上有很多关于window下Mysql自动备份的方法,其实不乏一些不好的地方和问题,现总结出一个最好的方法供大家参考: 新建一个记事本,然后重命名为: mysql_backup.bat 然后单击右键选 ...

  6. Windows下mysql忘记密码的解决方法

    Windows下mysql忘记密码的解决方法 mysql5.0 http://www.jb51.net/article/21984.htm方法一: 1.在DOS窗口下输入 net stop mysql ...

  7. Windows下MYSQL自动备份批处理

    windows下MYSQL自动备份批处理 2011-05-04 09:16:45|  分类: mysql|举报|字号 订阅     按系统时间进行备份 注意mysql安装路径中如果有空格.就要把,.b ...

  8. 【已解决】Windows下 MySQL大小写敏感 解决方案及分析

    Windows下 MySQL大小写敏感配置 zoerywzhou@163.com http://www.cnblogs.com/swje/ 作者:Zhouwan 2017-3-27 最近在window ...

  9. windows下mysql和linux下mysql主从配置

    1. linux下mysql安装版本5.6   windows下mysql版本5.7  不要问我为什么版本不一致  就是想这么搞 2. linux为主服务器   windows为从服务器 3.找到li ...

随机推荐

  1. MD中bitmap源代码分析--数据结构

    本篇分析bitmap的数据结构的设计,并基于此分析bitmap的工作机制. 为了后面更清楚的理解,先有个总体印象,给出整体的结构图: 在下面的描述中涉及到的内容可以对照到上图中相应部分,便于理解. 首 ...

  2. 上传jar包到Apache Archiva本地仓库

    1.登录archiva,点击左侧的upload Artifact 2 jar 包名称 为:java-client-4.1.2.jar 网上的pom配置为: <!-- https://mvnrep ...

  3. js 等待刷新技术

  4. (转)iOS5:[UIDevice uniqueIdentifier]的替代方案

    背景: 大多数应用都会用到苹果设备的UDID号,UDID通常有以下两种用途: 1)用于一些统计与分析目的:[第三方统计工具如友盟,广告商如ADMOB等] 2)将UDID作为用户ID来唯一识别用户,省去 ...

  5. 魔方公式xyz

    x:(整个魔方以R的方向转动),x':(整个魔方以R'的方向转动)  y:(整个魔方以U的方向转动),y':(整个魔方以U'的方向转动)  z:(整个魔方以F的方向转动),z':(整个魔方以F'的方向 ...

  6. Android邮件发送详解

    转载:http://flysnow.iteye.com/blog/1128354 Android中我为什么发不了邮件???我手机里明明有邮件客户端的,可我为什么不能调用它发送邮件???相信这是很多人会 ...

  7. linux权限及ntfs文件系统权限的知识

    关于ntfs权限的问题 文件的权限: [-dcbps][u:rwx][g:rwx][a:rwx] 当中: r=4, w=2, x=1,  u=owner, g=group, a=all user   ...

  8. Node.js 实现简单小说爬虫

    最近因为剧荒,老大追了爱奇艺的一部网剧,由丁墨的同名小说<美人为馅>改编,目前已经放出两季,虽然整部剧槽点满满,但是老大看得不亦乐乎,并且在看完第二季之后跟我要小说资源,直接要奔原著去看结 ...

  9. C++沉思录之三——设计容器类

    一.对容器的基本认识 总的来说,容器应该包含放在其中的对象的副本,而不是对象本身. 二.复制容器意味着什么? 通常将容器成为模板,而容器内的对象的类型就是模板参数.Container<T> ...

  10. 手贱随手在Linux敲了 as 命令,出不来了

    手贱随手在Linux敲了  as  命令,出不了命令,问问度娘吧,得到下列资料 as命令 GNU组织推出的一款汇编语言编译器,它支持多种不同类型的处理器.语法as(选项)(参数)选项-ac:忽略失败条 ...