双主其实说白了也是一个replication,只是推出一些新的拓扑结构

 
主-主的复制有两种模式:

主动-主动模式下的主-主复制(Master-Master in Active-Active Mode)
 
模式下的主-主复制(Master-Master in Active-Passive Mode)
 
当然还有,环形和有从服务器的主-主复制,不过都是上面的延生。
 
关于第一种的双主模式,肯定是会产生数据冲突的。虽然可以使用配置
auto_increment_increment=2和auto_increment_offset=1可以解决
自动插入的问题,允许同时插入数据的话,数据还是会不一致的。例如:
下面的两个命令同时执行:

第一个主服务器:
mysql>update tbl set col=col +1;
第二个主服务器:
mysql>update tbl set col=col*2;
 
结果是什么?一个服务器的值为4,而另外一个为3.并且根本没有replication的错误。
 
所以,个人建议主动-被动的双主模式,只让一台服务器写就行了,让它对外服务,
另外一台作为备用。只接受数据。
 
下面开始进入正题,如何配置双主。
 
第一步,启动来台数据库的时候,mysql.cnf都得配置下面的语句
 
3306:
server-id = 323306

log_slave_updates = 1
auto_increment_increment=2
auto_increment_offset=1
 
 
3307:
server-id = 323307
log_slave_updates = 1
auto_increment_increment=2
auto_increment_offset=2
read-only(保证只读)
 
当然每台服务器的port,user,socket,pid-file,basedir,datadir,tmpdir以及与log相关的:log-bin(这个是必须开启的),slow_query_log_file(当然也要开启)等等。就不说了。
 
这里最重要的就是log_slave_updates,没有它,双主是配不成的,关于它的详细介绍。在如下网址:
http://dev.mysql.com/doc/refman/5.5/en/replication-options-slave.html#option_mysqld_log-slave-updates
 
说白了,就是可以A -> B -> C,保证A可以作为master,复制到B,B可以作为master,复制到C.所以呢,如果A和B互相的话,就是双主了。
 
第二步,接着就是两台服务器都配上repl用户。
mysql> CREATE USER 'repl'@'192.168.1.50' IDENTIFIED BY 'repl';
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.1.50';
 
备注:'192.168.1.50'这个IP,是告诉来自于这个IP的主机有REPLICATION SLAVE的权限。
 
第三步,就跟配置replication是一样的。保证一致性的备份。
 
SHOW MASTER STATUS;知道对应的binlog.
 
再在slave上面进行change master to
mysql>CHANGE MASTER TO
MASTER_HOST = '192.168.1.40',
MASTER_PORT = 3306,
MSTER_USER = 'repl',
MASTER_PASSWORD = 'repl',
MASTER_LOG_FILE = 'mysql-bin.000004',
MASTER_LOG_POS = 107;
 
接着换过来,由于slave接受了master的binlog,自己又设置了log_slave_updates而且binlog也同时打开了,所以salva也可以看到自己的binlog。接着把上面的事情,同样再做一遍。即可
 
这样,双主就算配置成功。(没有什么太详细的步骤,不过基本上都说到位了。配置的话,跟mysql replication一致。http://blog.chinaunix.net/uid-26446098-id-3267475.html可以参考此文)
 
 
 

牛刀小试MySQL学习—MySQL 双主的更多相关文章

  1. Mysql + keepalived 实现双主热备读写分离【转】

    Mysql + keepalived 实现双主热备读写分离 2013年6月16日frankwong发表评论阅读评论   架构图 系统:CentOS6.4_X86_64软件版本:Mysql-5.6.12 ...

  2. MySQL 5.7双主同步部分表

    参考:http://www.jb51.net/article/122892.htm?pc 前言: 我们要配置双主同步的mysql服务器. 暂时叫做,mysql1和mysql2吧. 一  mysql的配 ...

  3. centos 下 mysql+keepalived实现双主自由切换

    目录 ip规划 mysql双主配置 keepalived配置 mysql1中keepalived的配置 mysql2中keepalived的配置 VIP漂移检测 本文的目的是搭建一个互为主从的mysq ...

  4. MySQL的主从复制+双主模式

    MySQL的主从复制 部署环境: MySQL master 192.168.40.21 MySQL slave  192.168.40.22 思路: 当主MySQL上进行数据上的操作或者变化时,主My ...

  5. MySQL 5.7 双主复制+keepalived,常规业务一般够用了

    业务需求: 为Zabbix搭建2个数据库,一个库给服务器监控用,一个库给网络监控用. 硬件: 两台服务器,硬盘是1.2 T SSD卡,内存128G 架构: 希望做双主复制+keepalived,架构大 ...

  6. [Mysql高可用]——双主互备+keepalived

    实验架构图    实验环境 主机名 操作系统 Mysql版本 keepalived版本 主机IP VIP lyj1(Master/Slave) Red Hat release 6.5 Mysql5.6 ...

  7. mysql主从复制及双主复制

    之前做过一次在单台机器上的多实例的mysql,这次分开做,使用两台主机. 这里使用的主机地址分别为: MASTER:192.168.214.135 SLAVE  : 192.168.214.128 这 ...

  8. mysql 5.7 双主+主从配置

    mysql5.7安装及赋权 wget http://repo.mysql.com/mysql57-community-release-el7-8.noarch.rpm rpm -ivh mysql57 ...

  9. Mysql之配置双主热备+keeepalived.md

    准备 1 1. 双主 master1 192.168.199.49 2 master2 192.168.199.50 3 VIP 192.168.199.52 //虚拟IP 4 2.环境 master ...

随机推荐

  1. [linux环境配置]个人用持续更新ing~

    alias ll='ls -la' export PATH=$PATH:~/Desktop/myscript alias gpush='git push origin HEAD:refs/for/ma ...

  2. bzoj1997 [Hnoi2010]Planar——2-SAT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1997 神奇的经典2-SAT问题! 对于两个相交的区间,只能一里一外连边,所以可以进行2-SA ...

  3. Docker为什么刚运行就退出了

    引言 最近群里的好多新接触Docker的朋友,好多都遇到了相同的问题,使用 $ docker run -d ubuntu /bin/bash 运行了一个简单的容器后,然后docker ps -a 进行 ...

  4. E20171015-hm

    quirk   n. 怪癖; 奇事,巧合; 突然的弯曲; propagation  n. 宣传; 传播,传输,蔓延,扩展,波及深度; [生]繁殖法,[地]传导; 培养; immediate  adj. ...

  5. mysql大数据的分表

    在实际业务运作中,我们经常遇到一个表中数据量过大的问题,这样的话,问题就来了.如何将一个表中的数据均衡的放到多个表中? 我的建议是,新建一个表,但是只有一个自增的id字段,将其作为分表的依据.有大数据 ...

  6. 慕课网3-10编程练习:简单的flex布局

    小伙伴们,我们学习了伸缩容器的一些属性,接下来使用我们所学的伸缩容器属性完成下面的效果图. 完成效果: 任务 1.先将容器设置为伸缩容器 2.在垂直方向上对齐,行与行之间的空白距离一样 3.在水平方向 ...

  7. VUE使用QRcode或者vue-qr生成二维码

    这里介绍两种vue生成二维码的方法 QRcode vue-qr vue-qr比QRcode功能多在可以在中间加logo 下面先介绍QRcode vue里安装qrcodejs的npm包 npm inst ...

  8. Entity Framework 4.3 中使用存储过程

    尽管 Entity Framework 4.3 都已经发布了,且表示在 EF 5 中性能将会有很大提升.但很多存储过程控,始终不会放弃使用存储过程,那今天就让我们看看在 EF 4.3 中怎么使用存储过 ...

  9. javascript中for...in和for...of的区别

    for...of循环是ES6引入的新的语法. for...in遍历拿到的x是键(下标).而for...of遍历拿到的x是值,但在对象中会提示不是一个迭代器报错.例子如下: let x; let a = ...

  10. 【洛谷2624_BZOJ1005】[HNOI2008] 明明的烦恼(Prufer序列_高精度_组合数学)

    题目: 洛谷2624 分析: 本文中所有的 "树" 都是带标号的. 介绍一种把树变成一个序列的工具:Prufer 序列. 对于一棵 \(n\) 个结点的树,每次选出一个叶子(度数为 ...