设为首页 收藏本站
查看: 801|回复: 0

[经验分享] mysql数据库的主从复制和主主复制

[复制链接]

尚未签到

发表于 2017-11-23 13:56:52 | 显示全部楼层 |阅读模式
Mysql主从架构技术说明Mysql内建的复制功能是构建大型,高性能应用程序的基础。将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机(Master)的数据复制到其它主机(slaves)上,并重新执行一遍来实现的。复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,这些日志可以记录发送到从服务器的更新。当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新。
数据库复制特性MySQL复制技术有以下一些特点:
(1) 数据分布 (Datadistribution )
(2) 负载平衡(load balancing)
(3) 备份(Backups)
(4) 高可用性和容错性 Highavailability and failover
Mysql复制如何工作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,查看主服务器二进制日志状态
02f822560452a577638d060771d97ff1.png
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线程正常运行
692e1f17aa851c44fcdf47b8113239db.png
接下来就可以测试了
在主服务器上创建一个名为xiaomi的表,在主服务器上可以查看到,如果在从服务器上也可以查看到,说明数据已同步,实现成功。
主服务器:

1e0ec7baa374fe2568aff9461549a76f.png
从服务器:
5b1f64fd9e4adf8b60118884c6b63122.png
主主复制


主主实际上也是互为主从,互为主从:两个节点各自都要开启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

3c309cd39f22b392a13b38b32bd446cc.png

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线程正常运行


测试:无论在哪个服务器的数据库中创建数据,另一个都可以同步数据。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-409885-1-1.html 上篇帖子: MYSQL-定时任务(event) 下篇帖子: mysql 5.5 .17 多实例的例子
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表