博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL主从复制与主主复制
阅读量:6947 次
发布时间:2019-06-27

本文共 4332 字,大约阅读时间需要 14 分钟。

mysql 的主从复制:

实验环境

linux CentOS7两台:192.168.230.10(主)----192.168.230.11(从)(系统安装好,关掉防火墙或配置好防火墙)

mysql 5.7(下载了官方的yum源,yum install -y mysql mysql-server)

开始配置

二进制日志开启

 一般Linux中的MySQL配置文件都在/etc/my.cnf(windows中的配置文件为mysql.ini)

server-id = 1 (在整个Mysql集群中保证唯一) log-bin = binlog (二进制文件) log-bin-index = binlog.index

           注意:二进制日志必须开启,因为数据的同步实质上就是其他的MySQL数据库服务器将这个数据变更的二进制日志在本机上再执行一遍。

开始构建:

第一步:

  在192.168.230.10中创建一个192.168.230.11主机中可以登录的MySQL用户

  用户:mysql11

  密码:Mysql@11(mysql5.7默认有密码复杂度验证,实际生产环境中也应该把密码设置复杂些)

mysql>GRANT REPLICATION SLAVE ON *.* TO 'mysql11'@'192.168.230.11' IDENTIFIED BY 'Mysql@11'; //登录地址可一写通配符192.168.230.%mysql>FLUSH PRIVILEGES; mysql>select host,user from user; ---------------------命令改成小写,大写看着费劲

grant replication slave on *.* to 'cong_server'@'%' identified by 'Mysql123@!'

flush privileges;

此时可以 锁定主服务器数据库,禁止数据的写入,确保pos不变.(可忽略)

第二步:在192.168.230.10中查看二进制文件和位置(查看主服务器的二进制文件和位置)

show master status;

第三步:

            (配置从服务器)告知二进制文件名与位置

            在192.168.230.11中执行://配置主服务器的信息

mysql>change master to>master_host=’192.168.230.10’,>master_user=’mysql11’,>master_password=’Mysql@11’, >master_log_file=’binlog.000003’,>master_log_pos=668; 或

CHANGE MASTER TO MASTER_HOST='192.168.230.10',MASTER_USER='mysql11',MASTER_PASSWORD='Mysql@11',MASTER_LOG_FILE='binlog.000003', MASTER_LOG_POS=668;

完成主从配置.

开启主从复制

在192.168.230.11中(slave翻译为奴隶)

mysql>start slave;   #开启复制  由此 stop slave;//肯定就是 停止了复制模式
mysql>show slave status\G   #查看主从复制是否配置成功

当看到Slave_IO_Running: YES、Slave_SQL_Running: YES才表明状态正常

测试

在主服务器192.168.230.10新建数据库,在从服务器查看有没有更新,(如果没有排查下 1.网络 2.密码 3.pos)

mysql 的主主复制:

实验原理

主主复制即在两台MySQL主机内都可以变更数据,而且另外一台主机也会做出相应的变更。聪明的你也许已经想到该怎么实现了。对,就是将两个主从复制有机合并起来就好了。只不过在配置的时候我们需要注意一些问题,例如,主键重复,server-id不能重复等等。

 配置文件

 --192.168.230.10

server-id=10   #任意自然数n,只要保证两台MySQL主机不重复就可以了。log-bin=binlog(mysql-bin)   #开启二进制日志auto_increment_increment=2   #步进值auto_imcrement。一般有n台主MySQL就填n(就是主键的自增1,3,5,7,9)auto_increment_offset=1   #起始值。一般填第n台主MySQL。此时为第一台主MySQL (设置第几个mysql服务器就填几,关系到id重复)binlog-ignore=mysql   #忽略mysql库【我一般都不写】binlog-ignore=information_schema   #忽略information_schema库【我一般都不写】replicate-do-db=aa   #要同步的数据库,默认所有库 /*我感觉主主复制是通过 auto_increment_increment 和 auto_increment_offset的设置来计算,来达到数据同步时id主键不会重复.*/

--192.168.230.11

server-id=11log-bin=binlog(mysql-bin)auto_increment_increment=2auto_increment_offset=2replicate-do-db=aa

配置好后重启MySQL

开始构建主主复制

因为主主复制是两个主从复制组合一起,所以我就接着上面主从复制接着配置。

第一步:在192.168.230.11中创建一个192.168.230.10可以登录的mysql用户

mysql>GRANT REPLICATION SLAVE ON *.* TO ‘mysql10’@’192.168.230.10’ IDENTIFIED BY ‘Mysql@10’; //登录地址可以写通配符 192.168.230.%mysql>FLUSH PRIVILEGES;mysql>select host,user from user; ------命令改小写

grant replication slave on *.* to 'cong_server'@'%' identified by 'Mysql123@!'

flush privileges;

第二步:在192.168.230.11中查看二进制文件和位置

mysql>show master status;

第三步:告知二进制文件和位置

在192.168.230.10中配置

mysql>CHANGE MASTER TO        >MASTER_HOST=’192.168.230.11’,        >MASTER_USER=’mysql10’,        >MASTER_PASSWORD=’Mysql@10’,        >MASTER_LOG_FILE=’binlog.000004’,        >MASTER_LOG_POS=154;或CHANGE MASTER TO MASTER_HOST='192.168.230.11',MASTER_USER='mysql10',MASTER_PASSWORD='Mysql@10',MASTER_LOG_FILE='binlog.000004', MASTER_LOG_POS=154;

开启复制 :  start slave;

查看复制状态:show slave status\G

 两个服务器都是主主了,都开启start slave;

测试

在192.168.230.10新建立数据库看 192.168.230.11有没有增加数据库

在192.168.230.11新建立数据库看 192.168.230.10有没有增加数据库

我测试正常~~

 

 注意事项

1、主主复制配置文件中auto_increment_increment和auto_increment_offset只能保证主键不重复,却不能保证主键有序。

2、当配置完成Slave_IO_Running、Slave_SQL_Running不全为YES时,show slave status\G信息中有错误提示,可根据错误提示进行更正。

3、Slave_IO_Running、Slave_SQL_Running不全为YES时,大多数问题都是数据不统一导致。

常见出错点:

1、两台数据库都存在db数据库,而第一台MySQL db中有tab1,第二台MySQL db中没有tab1,那肯定不能成功。

2、已经获取了数据的二进制日志名和位置,又进行了数据操作,导致POS发生变更。在配置CHANGE MASTER时还是用到之前的POS。

所以,进行主从是要进行锁库操作

不然数据在写入:flush tables with read lock;

取消主服务器数据库锁定:unlock tables;

 

3、stop slave后,数据变更,再start slave。出错。

终极更正法:重新执行一遍CHANGE MASTER就好了。

4.默认情况下主从复制自动启动的,如果让主从-主主复制不自动启动的话,需要在/etc/my.cnf中添加 skip-slave-start

 

转博文: http://www.cnblogs.com/phpstudy2015-6/p/6485819.html

下面介绍几个命令:

查看是否启用了日志mysql>show variables like 'log_bin';查看当前的日志mysql> show master status;看二进制日志文件用mysqlbinlogshell>mysqlbinlog mail-bin.000001是否启用了日志 mysql>show variables like '%log_bin%'; 怎样知道当前的日志 mysql> show master status; 显示二进制日志数目 mysql> show master logs;
/*主服务器为master 从服务器为slave (奴隶)*/
在从服务器上开启复制 start slave; 在从服务器上查看复制状态 show slave status\G 同理在主服务器查看 show master ststus\G

 

你可能感兴趣的文章
《测试驱动数据库开发》——2.4 增量构建
查看>>
网站图片优化你需要知道的地方
查看>>
《计算机科学概论》—第3章3.4节音频数据表示法
查看>>
深入理解Java内存模型(一)——基础
查看>>
C++程序设计:原理与实践(进阶篇)15.3 序列和迭代器
查看>>
后台开发:核心技术与应用实践2.3 类的多态
查看>>
智能哲学:在AI前沿上人类伦理学的挑战与应战
查看>>
简单5步隐藏Ubuntu13.04 Unity 启动器
查看>>
《Redis入门指南》一5.4 Node.js与Redis
查看>>
《精通Python网络爬虫:核心技术、框架与项目实战》——2.3 用户爬虫的那些事儿...
查看>>
《树莓派渗透测试实战》——导读
查看>>
《数据科学与大数据分析——数据的发现 分析 可视化与表示》一2.6 第5阶段:沟通结果...
查看>>
《OpenGL ES 2.0游戏开发(上卷):基础技术和典型案例》——6.4节点法向量和面法向量...
查看>>
Storm-源码分析- Storm中Zookeeper的使用
查看>>
《Android 应用案例开发大全(第3版)》——导读
查看>>
Redis开发与运维. 2.2 字符串
查看>>
中化集团牵手阿里云拥抱互联网+ 打造领先的化工行业B2B垂直电商
查看>>
《C++面向对象高效编程(第2版)》——4.7 对象相等的语义
查看>>
《贝叶斯思维:统计建模的Python学习法》一1.7 Monty Hall难题
查看>>
《Kafka官方文档》设计(一)
查看>>