MySQL主从复制虽好,能完美解决数据库单点问题吗?

2019 年 2 月 10 日 DBAplus社群


一、单个数据库服务器的缺点


  • 数据库服务器存在单点问题;

  • 数据库服务器资源无法满足增长的读写请求;

  • 高峰时数据库连接数经常超过上限。


二、如何解决单点问题


  • 增加额外的数据库服务器,组建数据库集群;

  • 同一集群中的数据库服务器需要具有相同的数据;

  • 集群中的任一服务器宕机后,其它服务器可以取代宕机服务器。


三、MySQL主从复制架构


1、主库将变更写入到主库的binlog中


  • 一些MySQL版本并不会开启二进制日志,所以一定要检查是否开启;

  • 如果刚开始没有开启,后面再进行开启的话,需要重启数据库才能生效,而且数据库的重启往往会对业务造成很大的影响;

  • 尽管二进制日志对性能有稍许的影响,所以还是建议大家无论是否使用复制功能,都要开启MySQL二进制日志,因为增量备份也需要二进制日志。


2、从库的IO线程在指定位置读取主库binlog内容存储到本地的中继日志(Relay Log)中


要完成二进制日志的传输过程,MySQL会在从服务器上启动一个工作线程,称为IO线程,这个IO线程会跟主数据库建立一个普通的客户端连接,然后在主服务器上启动一个特殊的二进制转储线程称为binlogdown线程。


从库上的IO线程通过这个二进制转储线程来读取主库上的二进制事件,如果该事件追赶上主库,则会进入sleep状态,直到主库发起信号通知有新事件产生时,才会被唤醒,relay log的格式和binlog格式是完全相同的,


可以使用mysqlbinlog来读取relay log中的内容。


3、从库的SQL线程读取Relay Log日志中的内容,并在从库中重放


SQL线程所执行的事件,我们可以通过配置选项来决定是否要写入到从服务器的二进制日志中。


目前MySQL支持两种复制类型:


  • 基于二进制日志点的复制

  • 基于GTID的复制(MySQL>=5.7推荐使用)


四、MySQL主从配置步骤


1、配置主从数据库服务器参数


有些参数配置后需要数据库重启才能生效,为了不影响数据库的正常使用,我们最好在服务器上线的同时就把参数都配置好。特别是master服务器的参数,更应该作为服务器初始参数来进行配置。


master服务器:



slave 服务器:



2、在master服务器上创建用于复制的数据库账号


用于IO线程连接master服务器获取binlog日志,需要* REPLICATION SLAVE** 权限:


create user 'repl'@'ip段' identified by 'password';

    grant replication slave on *.* to 'repl'@'ip段';


3、备份master服务器上的数据并初始化slave服务器数据


  • 建议主从数据库服务器采用相同的MySQL版本;

  • 建议使用全库备份的方式初始化slave数据。


采用相同版本的好处:


  • 我们可以使用全备的方式来初始化slave数据,还可以避免不同版本之间的差异造成数据库同步失败的问题。

  • 如果我们使用的主从复制的服务器MySQL版本不同,则一定要注意master上的版本一定要低于slave服务器,不然同步的时候就可能出现错误。


由于我们演示过程中的MySQL服务器都是使用的MySQL5.7,所以我们可以使用全备的方式进行:


mysqldump --master-data=2 -uroot -p -A --single-transaction -R --triggers


4、启动基于日志点的复制链路


在slave服务器上运行,MySQL命令:


CHANGE MASTER TO

MASTER_HOST= 'master_host_ip',

MASTER_USER= 'repl',

MASTER_PASSWORD = 'password',

MASTER_LOG_FILE='mysql_log_file_name',

MASTER_LOG_POS=xxxxxx;


5、启动基于GTID的复制链路


GTID:全局事务ID,GTID可以保证每一个在主上提交的事务,在复制集群中可以生成一个唯一的ID值,要使用基于GTID的复制,我们要在主从复制的配置文件中同时加入以下配置项。


MySQL配置:


gtid_mode=on # 是否启动gtid模式,启动了此模式会在二进制日志中会额外记录每个事务的GTID标识符

enforce-gtid-consistency    # 强制gtid一致性,用于保证启动gtid后事务的安全

log-slave-updates = on    # mysql5.6一定要启用参数,5.7可以不启用


MySQL命令:


CHANGE MASTER TO

MASTER_HOST= 'master_host_ip',

MASTER_USER= 'repl',

MASTER_PASSWORD = 'password',

MASTER_AUTO_POSITION=1;


GTID复制的限制:


  • 无法再使用create table ... select语句建立表,只能先create表,再insert数据;

  • 无法在事务中使用create temporary table建立临时表;

  • 无法使用关联更新同时更新事务表和非事务表。


4和5中选一个执行即可。


五. MySQL主从复制演示


1. 先对主服务器进行配置



由于主服务器一直在运行着,在生产环境中主服务器是很少会重启的,如果主服务器重启,会造成正常的业务访问的中断,所以在服务器启动之前就启动了二进制日志。


这里不需要重启主服务器了,由于主服务器的默认server_id=1,我们虽然在配置文件中更改了它的值 ,但实际运行环境中并没有改变。


我们可以查看一下当前server_id:


mysql> show variables like '%server_id%';


可以通过以下命令动态的进行修改:


mysql> set global server_id = 100;


2. 再对从服务器进行配置



修改完从服务器配置后,重启MySQL服务器。如果使用的是MySQL5.7版本的需要注意:


  • MySQL5.7增加了server-uuid值,默认情况下载auto.cnf文件中,如果是使用的镜像的方式安装,可能大家的uuid一样 ,所以需要把auto.cnf文件删除掉。MySQL重启后会自动重新生成uuid的值,这样就可以保证不同服务器上的MySQL实例的uuid的值是不一样的;

  • 如果server-uuid的值相同,主从复制会出现问题。


以上我们就完成了主从复制的配置,接下来我们要在主服务器上建立复制账号。


3. 在MySQL主服务器上建立MySQL复制账号


mysql> create user 'dba_repl'@'192.168.3.%' identified by '123456';

mysql> grant replication slave on *.* to 'dba_repl'@'192.168.3.%';


4. 建立好复制账号以后,通过mysql主服务器上的全备初始化从服务器上数据


进行全备:


[root@localhost data]# cd /data/db_backup/

[root@localhost db_backup]#  mysqldump -uroot -p --master-data=1 --single-transaction --routines --triggers --events  --all-databases > all.sql

Enter password: 


将其拷贝到从服务器上:


[root@localhost db_backup]# scp all.sql root@192.168.3.101:/root


在从服务器上恢复备份进行初始化:


[root@Node2 ~]# mysql -uroot -p < all.sql


初始化完成后,准备。


5. 从服务器进行基于日志点的复制链路的配置


mysql> change master to master_host='192.168.3.100',

        -> master_user='dba_repl',

        -> master_password='123456',

        ->MASTER_LOG_FILE='mysql-bin.000017',MASTER_LOG_POS=663;

MASTER_LOG_FILE和MASTER_LOG_POS的值从全备文件中的CHANGE MASTER中获取


以上复制链路的配置完成。


启动slave:


mysql> start slave;


检查是否启动成功状态:


mysql> show slave status \G


显示:


Relay_Master_Log_File: mysql-bin.000017

Slave_IO_Running:Yes

Slave_SQL_Running: Yes


说明启动成功了,可以在主服务器上插入数据,在从服务上查看数据是否同步过来了。


六. 主从复制的一些缺点


虽然主从复制增加了一个数据库副本,但从数据库和主数据库的数据最终会是一致的。之所以说是最终一致,因为MySQL复制是异步的,正常情况下主从复制数据之间会有一个微小的延迟。


通过这个数据库副本看似解决了数据库单点问题,但并不完美:因为这种架构下,如果主服务器宕机,需要手动切换从服务器,业务中断不能忍受,不能满足应用高可用的要求。


如大家对内容有更多想法及建议,欢迎留言交流~


作者:听风

来源:https://www.cnblogs.com/huchong/p/10253522.html

dbaplus社群欢迎广大技术人员投稿,投稿邮箱:editor@dbaplus.cn



近期热文

知乎容器化构建系统:从0到1支撑日近万次构建部署

再有人问你分布式锁,就把这个丢给他!

适合中小企业,解锁不同场景X86服务器虚拟化方案

数十个SQL审核项目后,我总结出了这样一套经验

当数据库扼住系统性能咽喉,直接分库分表能解决吗?


登录查看更多
0

相关内容

数据库服务器由运行在局域网中的一台/多台计算机和数据库管理系统软件共同构成,数据库服务器为客户应用程序提供数据服务。
【实用书】学习用Python编写代码进行数据分析,103页pdf
专知会员服务
194+阅读 · 2020年6月29日
【干货书】现代数据平台架构,636页pdf
专知会员服务
255+阅读 · 2020年6月15日
Python导论,476页pdf,现代Python计算
专知会员服务
260+阅读 · 2020年5月17日
【书籍推荐】简洁的Python编程(Clean Python),附274页pdf
专知会员服务
180+阅读 · 2020年1月1日
【干货】大数据入门指南:Hadoop、Hive、Spark、 Storm等
专知会员服务
95+阅读 · 2019年12月4日
在K8S上运行Kafka合适吗?会遇到哪些陷阱?
DBAplus社群
9+阅读 · 2019年9月4日
PC微信逆向:两种姿势教你解密数据库文件
黑客技术与网络安全
16+阅读 · 2019年8月30日
携程用ClickHouse轻松玩转每天十亿级数据更新
DBAplus社群
11+阅读 · 2019年8月6日
工行基于MySQL构建分布式架构的转型之路
炼数成金订阅号
15+阅读 · 2019年5月16日
数据库之架构:主备+分库?主从+读写分离?
架构文摘
8+阅读 · 2019年4月23日
亿级订单数据的访问与储存,怎么实现与优化
ImportNew
11+阅读 · 2019年4月22日
亿级订单数据的访问与存储,怎么实现与优化?
码农翻身
16+阅读 · 2019年4月17日
使用 Canal 实现数据异构
性能与架构
20+阅读 · 2019年3月4日
Python 杠上 Java、C/C++,赢面有几成?
CSDN
6+阅读 · 2018年4月12日
基于 Storm 的实时数据处理方案
开源中国
4+阅读 · 2018年3月15日
Do RNN and LSTM have Long Memory?
Arxiv
19+阅读 · 2020年6月10日
Image Captioning: Transforming Objects into Words
Arxiv
7+阅读 · 2019年6月14日
Music Transformer
Arxiv
5+阅读 · 2018年12月12日
Exploring Visual Relationship for Image Captioning
Arxiv
15+阅读 · 2018年9月19日
Arxiv
5+阅读 · 2017年11月13日
VIP会员
相关资讯
在K8S上运行Kafka合适吗?会遇到哪些陷阱?
DBAplus社群
9+阅读 · 2019年9月4日
PC微信逆向:两种姿势教你解密数据库文件
黑客技术与网络安全
16+阅读 · 2019年8月30日
携程用ClickHouse轻松玩转每天十亿级数据更新
DBAplus社群
11+阅读 · 2019年8月6日
工行基于MySQL构建分布式架构的转型之路
炼数成金订阅号
15+阅读 · 2019年5月16日
数据库之架构:主备+分库?主从+读写分离?
架构文摘
8+阅读 · 2019年4月23日
亿级订单数据的访问与储存,怎么实现与优化
ImportNew
11+阅读 · 2019年4月22日
亿级订单数据的访问与存储,怎么实现与优化?
码农翻身
16+阅读 · 2019年4月17日
使用 Canal 实现数据异构
性能与架构
20+阅读 · 2019年3月4日
Python 杠上 Java、C/C++,赢面有几成?
CSDN
6+阅读 · 2018年4月12日
基于 Storm 的实时数据处理方案
开源中国
4+阅读 · 2018年3月15日
相关论文
Do RNN and LSTM have Long Memory?
Arxiv
19+阅读 · 2020年6月10日
Image Captioning: Transforming Objects into Words
Arxiv
7+阅读 · 2019年6月14日
Music Transformer
Arxiv
5+阅读 · 2018年12月12日
Exploring Visual Relationship for Image Captioning
Arxiv
15+阅读 · 2018年9月19日
Arxiv
5+阅读 · 2017年11月13日
Top
微信扫码咨询专知VIP会员