Mysql内建的复制功能是构建大型,高性能应用程序的基础。将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机(Master)的数据复制到其它主机(slaves)上,并重新执行一遍来实现的。复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,这些日志可以记录发送到从服务器的更新。当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新。
MySQL复制技术有以下一些特点:
(1) 数据分布 (Datadistribution )
(2) 负载平衡(load balancing)
(3) 备份(Backups)
(4) 高可用性和容错性 Highavailability and failover
1、该过程的第一部分就是master记录二进制日志。在每个事务更新数据完成之前,master在二进制日志记录这些改变。MySQL将事务串行的写入二进制日志,在事件写入二进制日志完成后,master通知存储引擎提交事务。此后可接收slave的请求
2、下一步就是slave将master的binary log拷贝到它自己的中继日志。首先,slave开始一个工作线程——I/O线程。I/O线程在master上打开一个普通的连接,然后开始在主节点上binlog dump process(二进制转存线程)。Binlog dump process从master的二进制日志中读取事件,如果已经跟上master,它会睡眠并等待master产生新的事件。I/O线程将这些事件写入中继日志。
3、 SQL slave thread(SQL从线程)处理该过程的最后一步。SQL线程从中继日志读取事件,并重放其中的事件而更新slave的数据,使其与master中的数据一致。只要该线程与I/O线程保持一致,中继日志通常会位于OS的缓存中,所以中继日志的开销很小。
实验环境:
centos 系统服务器2 台、一台用户做Mysql 主服务器,一台用于做Mysql从服务器,配置好yum 源、防火墙关闭、各节点时钟服务同步、各节点之间可以通过主机名互相通信。实验中我用的是centos7。
Mysql主服务器:192.168.182.173
mysql从服务器: 192.168.182.174
实验步骤:
一:配置主服务器
1.修改配置文件
vim /etc/my.cnf
server-id=1 #配置server-id,让主服务器有唯一ID号
log-bin=mysql-bin #打开Mysql日志,日志格式为二进制
skip-name-resolve #关闭名称解析,(非必须)
2.查看主服务器状态
在Master的数据库执行show master status,查看主服务器二进制日志状态
3.创建复制帐号
在Master的数据库中建立一个备份帐户:每个slave使用标准的MySQL用户名和密码连接master。进行复制操作的用户会授予replication slave权限。
grant replication slave on *.* to ‘slave‘@‘192.168.182.174‘identified by ‘magedu‘;
二:配置从服务器
1.修改配置文件
vim /etc/my.cnf
server-id=2 #配置server-id,让从服务器有唯一ID号
relay_log = mysql-relay-bin #打开Mysql日志,日志格式为二进制
read_only = 1 #设置只读权限
log_bin = mysql-bin #开启从服务器二进制日志
log_slave_updates = 1 #使得更新的数据写进二进制日志中
2.启动从服务器复制线程
让slave连接master,并开始重做master二进制日志中的事件。
CHANGE MASTER TO MASTER_HOST=‘192.168.222.128‘,
MASTER_USER=‘slave‘,
MASTER_PASSWORD=‘magedu‘,
MASTER_LOG_FILE=‘mysql-bin.000001‘,
MASTER_LOG_POS=245;
执行start slave;# 启动复制线程。
3.查看从服务器状态
可使用SHOW SLAVE STATUS\G查看从服务器状态,如下所示,也可用show processlist \G查看当前复制状态:
Slave_IO_Running: Yes #IO线程正常运行
Slave_SQL_Running: Yes #SQL线程正常运行
接下来就可以测试了
在主服务器上创建一个名为xiaomi的表,在主服务器上可以查看到,如果在从服务器上也可以查看到,说明数据已同步,实现成功。
主服务器:
从服务器:
主主复制
主主实际上也是互为主从,互为主从:两个节点各自都要开启binlog和relay log;
1、数据不一致;
2、自动增长id;
定义一个节点使用奇数id
auto_increment_increment=2#表示自增长字段每次递增的量
auto_increment_offset=1#表示自增长字段从那个数开始
另一个节点使用偶数id
auto_increment_increment=2
auto_increment_offset=2
实验:主主复制
在上面主从实验的基础上,实现主主复制。
主服务器:192.168.182.174
从服务器:192.168.136.173
一:配置主服务器
vim /etc/my.cnf
server-id=2 #配置server-id,让主服务器有唯一ID号
log-bin=mysql-bin #打开Mysql日志,日志格式为二进制
relay_log=mysql-relay-log
auto_increment_increment=2
auto_increment_increment=2
2.查看主服务器状态
在Master的数据库执行show master status,查看主服务器二进制日志状态
3.创建复制帐号
在Master的数据库中建立一个备份帐户:每个slave使用标准的MySQL用户名和密码连接master。进行复制操作的用户会授予replication slave权限。
grant replication slave on *.* to ‘slave‘@‘192.168.182.174‘identified by ‘magedu‘;
二:修改从服务器配置文件
1.vim /etc/my.cnf
server-id=2 #配置server-id,让主服务器有唯一ID号
log-bin=mysql-bin #打开Mysql日志,日志格式为二进制
relay_log=mysql-relay-log
auto_increment_increment=2
auto_increment_increment=2
2.启动从服务器复制线程
让slave连接master,并开始重做master二进制日志中的事件。
CHANGE MASTER TO MASTER_HOST=‘192.168.182.174‘,
MASTER_USER=‘slave1‘,
MASTER_PASSWORD=‘magedu1‘,
MASTER_LOG_FILE=‘mysql-bin.000001‘,
MASTER_LOG_POS=245;
执行start slave;# 启动复制线程。
3.查看从服务器状态
可使用SHOW SLAVE STATUS\G查看从服务器状态,如下所示,也可用show processlist \G查看当前复制状态:
Slave_IO_Running: Yes #IO线程正常运行
Slave_SQL_Running: Yes #SQL线程正常运行
测试:无论在哪个服务器的数据库中创建数据,另一个都可以同步数据。
本文出自 “13162732” 博客,请务必保留此出处http://13172732.blog.51cto.com/13162732/1983889
原文地址:http://13172732.blog.51cto.com/13162732/1983889