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

[经验分享] Mysql实现企业级数据库主从复制架构实战

[复制链接]

尚未签到

发表于 2017-11-23 11:21:41 | 显示全部楼层 |阅读模式
本帖最后由 wred 于 2017-11-23 11:23 编辑

一、数据库的主从复制
Mysql内建的复制功能是构建大型,高性能应用程序的基础。将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机(Master)的数据复制到其它主机(slaves)上,并重新执行一遍来实现的。复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,这些日志可以记录发送到从服务器的更新。当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新。
Mysql的复制功能主要有3个步骤:
(1)主服务器(master)将改变记录到二进制日志(binarylog)中(这些记录叫做二进制日志事件,binary log events)
(2)从服务器(slave)将主服务器master的binary logevents拷贝到它的中继日志(relay log)
(3)slave重做中继日志中的事件,将改变反映它自己的数据。
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的缓存中,所以中继日志的开销很小。
Mysql主从复制大致流程图
6b5d7e97a1498b0fcd84350a95743468.png-wh_500x0-wm_3-wmp_4-s_434681530.png
Mysql主从复制架构实战演练:
1,准备两台虚拟机
master 172.17.254.242
slave 172.17.254.249
清空防火墙策略,关闭selinux。使用yum安装好mysql,并启动mysql
2,相关配置文件
a、配置master主服务器
    server-id=1        #配置server-id,让主机有唯一id号
    log-bin=mysql-bin     #开启二进制日志
b、在Master的数据库中建立一个备份帐户:每个slave使用标准的MySQL用户名和密码连接master 。进行复制操作的用户会授予REPLICATION SLAVE权限。
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO slave@'172.17.%.%' IDENTIFIED BY 'centos';
c、使用命令show master status;查看二进制日志
6e834ed3eac7374d6d1ab9e4366152f5.png-wh_500x0-wm_3-wmp_4-s_1591484660.png

d、配置slave服务器
    server-id=2           #切记server-id必须是唯一的不能重复

    relay-log=mysql-relay-log     #开启中继日志

    read-only=1           #设置只读权限
    log-bin=mysql-bin        #开启从服务器二进制日志
    log_slave_updates=1      #使得更新的数据写进二进制日志

e、启动从服务器复制线程让slave连接master,并开始重做master二进制日志中的事件。
CHANGE MASTER TO MASTER_HOST='172.17.254.242',
MASTER_USER='slave',
MASTER_PASSWORD='centos',
MASTER_LOG_FILE='mysql-bin.000006',
MASTER_LOG_POS=245;
执行start slave;# 启动复制线程。
f、查看从服务器状态可使用SHOW SLAVE STATUS\G查看从服务器状态
Slave_IO_Running: Yes #IO线程正常运行
Slave_SQL_Running: Yes #SQL线程正常运行
9564b1c3351190fbece20477d1fc7f63.png-wh_500x0-wm_3-wmp_4-s_2170661831.png
测试:
在master服务器上创建一个数据库create database test;
在slave服务器上使用命令show databases;会发现test库
实现了两台服务器的数据的一致性
注意事项:在做实验过程中如果在slave服务器上出现了Slave_IO_Running:Connecting/No问题,首先先检查一下防火墙是否已经关闭;如果不是此问题,检查一下二进制日志以及配置文件是否相对应如果以上问题都没有出现,可能就是slave有残余日志文件,在slave服务器上使用命令reset slave,然后重新开启一下start slave就可以了。


运维网声明 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-409817-1-1.html 上篇帖子: 编译安装MySQL-5.5.28 下篇帖子: 创建mysq数据库,并创建管理用户
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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