mysql被动模式下的主主配置
mysql 架构最简单用得也最多的的是主从,主主等,主从有个切换的问题,从库不可写,在主库一定的情况下,切换挺麻烦,这里可以用主主模式。
但是主主也有个问题,就是两边同时写有可能冲突,主键冲突,虽然可以用奇偶主键方式来解决,或者程序来做,但是增加了麻烦,这里用被动模式下的主主就方便多了。
两台服务器设置
1.两台服务器都设置上二进制日志和relay日志:
#给服务器命名一个id
server_id=140
#声明二进制日志的文件为mysql-bin.xxx
log-bin=mysql-bin
#二进制日志的格式:mixed/row/statement
binlog_format=mixed
#主主复制时都需要配置relay-log
relay-log=mysql-relay
2.都给对付赋权并设置对付对方为自己的主
20:GRANT replication slave ON *.* to 'repl'@'10.0.67.19' identified by '123456';
19:change master to master_host='10.0.67.20', master_user='repl', master_password='123456',master_port=3306, master_log_file='mysql-bin.000004', master_log_pos=1318;
19:GRANT replication slave ON *.* to 'repl'@'10.0.67.20' identified by '123456';
20:change master to master_host='10.0.67.19', master_user='repl', master_password='123456',master_port=3306, master_log_file='mysql-bin.000004', master_log_pos=1318;
3.开启slave:
start slave
4.查看slave状态
show slave status\G
被动模式下的主主复制:
1.概念:是指2台服务器地位一样,但其中一台为只读,并且业务中也只写某1台服务器;
2.好处:如果供写入的服务器出了故障,能迅速的切换到从服务器,或者出于检修等目的,把写入功能切换到另一台服务器也比较方便;
3.实现:在只读服务器的my.cnf中加入如下配置:read-only=on;
同步冲突问题:
摘录:
1.主主复制下一定要注意避免的问题,同步冲突,例:
create table stu (
id int primary key auto_increment.
)......
2台mysql地位相等, 假如2个请求同时到达2台服务器,请求的A节点stu的id为1,请求的B节点stu的id为1,此时就产生了同步冲突的问题;
2.解决方案:
让A服务器的主键通过奇数增长,B服务器的主键通过偶数增长;
A服务器:
set global auto_increment_increment = 2; //每次自增步长
set global auto_increment_offset = 1; //初始自增的数字
set session auto_increment_increment = 2;
set session auto_increment_offset = 1;
B服务器:
set global auto_increment_increment = 2;
set global auto_increment_offset = 2;
set session auto_increment_increment=2;
set session auto_increment_offset = 2;
注:auto-increment-increment 和auto-increment-offset要写到配置文件中,防止下次重启后失效;
注:如果后期需要加服务器,这个办法就有限制了
方法:我们可以在业务逻辑上来解决,比如在oracle有sequence序列,序列每次访问生成递增/递减的数据,以redis为例,我们可以专门构建一个 global:userid,每次PHP插入Mysql前,先 incr->global:userid,得到一个不重复的userid;
mysql被动模式下的主主配置的更多相关文章
- MySQL之RPM安装说明及配置
1.查看当前系统是否安装过Linux rpm -qa | grep -i mysql 未安装无任何输出:安装会打印对应mysql的rpm安装包. 2.准备安装包: MySQL-client-5.5.4 ...
- CentOS 6.5 下MySql主从、主主配置
参考网站: http://blog.csdn.net/faye0412/article/details/6280761 http://blog.csdn.net/kk185800961/article ...
- mysql数据库主从及主主复制配置演示
实验系统:CentOS 6.6_x86_64 实验前提:提前准备好编译环境,防火墙和selinux都关闭 实验说明:本实验共有2台主机,IP分配如拓扑 实验软件:mariadb-10.0.20 实验拓 ...
- mysql主主复制(双主复制)配置步骤
以前我们介绍的都是主从复制,这里给各位介绍一个双主复制了,下面都希望两个主服务器数据自动复制的话可参考一下此文章. MySQL主主复制结构区别于主从复制结构.在主主复制结构中,两台服务器的任何一台 ...
- mysql 主主复制(双主复制)+ 配置KEEPALIVED实现热备
binlog-do-db和replicate-do-db表示需要同步的数据库 binlog-ignore-db和replicate-ignore-db表示不需要同步的数据库 云端服务器为master配 ...
- mysql传统主从、双主复制+keepalived配置步骤
mysql主从.主主复制(双主复制)配置步骤 一:MySQL复制: MySQL复制简介: 将master服务器中主数据库的ddl和dml操作通过二进制日志传到slaves服务器上,然后在master服 ...
- mysql的主从配置以及主主配置
基础环境 系统:linuxmysql版本:5.5主服务器IP:192.168.1.101从服务器IP:192.168.1.102 1.主服务器(master)要打开二进制日志2.从服务器(slave) ...
- MySQL 主主同步配置和主从配置步骤
★预备知识 : 1.双机热备 对于双机热备这一概念,我搜索了很多资料,最后,还是按照大多数资料所讲分成广义与狭义两种意义来说. 从广义上讲,就是对于重要的服务,使用两台服务器,互相备份,共同执行同一服 ...
- MySQL Replication, 主从和双主配置
MySQL Replication, 主从和双主配置 MySQL的Replication是一种多个MySQL的数据库做主从同步的方案,特点是异步,广泛用在各种对MySQL有更高性能,更高可靠性要求的场 ...
随机推荐
- CentOS 7 下nagios搭建记录
跟随 园子的文章搭建 http://www.cnblogs.com/mchina/archive/2013/02/20/2883404.html 1.遇 nagios插件地址迁移错误,记录解决. 2. ...
- pandas操作,感觉不错,复制过来的
整理pandas操作 本文原创,转载请标识出处: http://www.cnblogs.com/xiaoxuebiye/p/7223774.html 导入数据: pd.read_csv(filenam ...
- jvm-监控指令-jstack
格式: jstack [option] vmid 选项: -l 除了堆栈信息外,显示关于锁的附加信息. 作用: 生成虚拟机当前时刻的线程快照. 目的: 定位线程长时间停顿的原因,比如线程间死锁.死循环 ...
- mysql replication 复制的一些问题
1 过大的复制延迟 mysql 的复制延迟是一个常见问题,现在已经有一些解决方案,如淘宝开发的一些工具 2 没有磁盘空间 复制导致磁盘空间塞满,二进制日志.中继日志或临时文件把磁盘塞满,slave ...
- Android 中AlarmManager升级4.2
- SpringBoot定时任务(Spring Schedule )实现方法
FastDateFormat fdf = FastDateFormat.getInstance("yyyy-MM-dd HH:mm:ss"); fdf.format(new Dat ...
- SHAREPOINT 2013 + PROJECT 2013 资料网站
1.http://technet.microsoft.com/zh-CN/sharepoint 2\ 博客圆专业讲解 http://www.cnblogs.com/jianyus/archive/2 ...
- SpringBoot整合Quartz定时任务
记录一个SpringBoot 整合 Quartz 的Demo实例 POM.XML文件 <!-- 定时器任务 quartz需要导入的坐标 --> <dependency> < ...
- Node.js 调用 restful webservice
如何构建一个restful web service参考原来的文章 http://www.cnblogs.com/ericnie/p/5212748.html 直接用原来的项目编译好像有问题,此处耗费1 ...
- javascript快速入门20--Cookie
Cookie 基础知识 我们已经知道,在 document 对象中有一个 cookie 属性.但是 Cookie 又是什么?“某些 Web 站点在您的硬盘上用很小的文本文件存储了一些信息,这些文件就称 ...