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

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

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

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

二、如何解决单点问题

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

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

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

三、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

初始化完成后,准备。

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

1主5从mysql数据库_MySQL主从复制虽好,能完美解决数据库单点问题吗?相关推荐

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

    一.单个数据库 服务器 的缺点 数据库服务器存在单点问题: 数据库服务器资源无法满足增长的读写请求: 高峰时数据库连接数经常超过上限. 二.如何解决单点问题 增加额外的数据库服务器,组建数据库集群: ...

  2. 高可用Mysql架构_Mysql主从复制、Mysql双主热备、Mysql双主双从、Mysql读写分离(Mycat中间件)、Mysql分库分表架构(Mycat中间件)的演变...

    [Mysql主从复制] 解决的问题 数据分布:比如一共150台机器,分别往电信.网通.移动各放50台,这样无论在哪个网络访问都很快.其次按照地域,比如国内国外,北方南方,这样地域性访问解决了. 负载均 ...

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

    点击上方"朱小厮的博客",选择"设为星标" 回复"1024"获取独家整理的学习资料 一.单个数据库服务器的缺点 数据库服务器存在单点问题: ...

  4. MySQL主从复制能完美解决数据库单点问题吗?

    一.单个数据库服务器的缺点 数据库服务器存在单点问题: 数据库服务器资源无法满足增长的读写请求: 高峰时数据库连接数经常超过上限. 二.如何解决单点问题 增加额外的数据库服务器,组建数据库集群: 同一 ...

  5. hibernate mysql 主从_MYSQL主从复制和写分离

    基础篇https://edu.51cto.com/course/19845.html https://edu.51cto.com/course/19845.html https://edu.51cto ...

  6. mysql 多项式_mysql主从复制原理及实现

    一.主从复制原理 利用MySQL提供的Replication,其实就是Slave从Master获取Binary log文件,然后再本地镜像的执行日志中记录的操作.由于主从复制的过程是异步的,因此Sla ...

  7. java读取mysql配置文件_MySql主从复制,从原理到实践

    推荐阅读: 成功斩获头条offer,Java程序员心得分享给你春招助力 摘要 本文将从MySql主从复制的原理出发,详细介绍MySql在Docker环境下的主从复制搭建,以一个主实例和一个从实例实现主 ...

  8. mysql shell 回车换行_【shell mysql 导出数据到csv脚本,完美解决乱码转义符等问题】-费元星...

    #!/bin/bash #@author:feiyuanxing [既然笨到家,就要努力到家] #@date:2017-12-05 #@E-Mail:feiyuanxing@gmail.com #@T ...

  9. mysql 2003 10038_关于MySql10038错误的完美解决方法(三种)

    第一种方法: 第一步: 先看报错窗口 2003 can't connect to MySQL server on '127.0.0.1'(10038). 第二步: 原因是:远程3306端口未对外开放操 ...

最新文章

  1. 解放你内心的自然领袖,从你的内心而非你的自我来领导你自己
  2. python读取.so_Python入门-编译安装Python3教程
  3. makefile文件的一些解读
  4. NOIP2018-普及参赛总结
  5. PAT乙:1022 D进制的A+B
  6. 解决nginx部署后css、js、图片等样式不加载的问题
  7. 计算机视觉未有深度学习之前
  8. WIn10 Odoo10.0 解决开发环境登录后无法加载菜单,js报错
  9. MSSQL获取当前日期及格式
  10. 串级PID控制(多闭环PID控制)的理解
  11. html 数据交互动画,H5交互动画创作平台推荐:爆米兔和木疙瘩
  12. RabbitMQ交换机的讲解
  13. 作业三:代码规范、代码复审、PSP
  14. 锁相放大器在中微流控的应用
  15. PHP的电子邮件列表替代方法:使用Mailgun的List API
  16. php创蓝253四要素认证_【PHP】创蓝253云通讯平台国际短信API接口demo
  17. 隐私计算 — 联邦学习 — Overview
  18. Android适合手机开发的又一力证——安卓街机
  19. MIUI 12 安装谷歌套件 解决升级miui后无法使用谷歌套件的问题 适用于升级到android11后无法使用三件套 点击登录没反应的情况
  20. 小程序客服关闭自动回复功能后如何解决关注公众号

热门文章

  1. VS2010中使用sprintf出现warning C4997: 'sprintf': This function or variable may be unsafe.
  2. Vue + Element UI 实现 登陆注册基本demo实例
  3. mysql数据库关联练习_mysql数据库建立数据表的练习(附代码)
  4. Win10系统局域网中的其他电脑能Ping通但是无法访问本地IIS发布的网站
  5. 三维数据平滑处理_关于CAD三维对象建模
  6. python数据库自动重连_python mysql断开重连的实现方法
  7. 计算机有必要报英语四级吗,我已工作了,现在有必要去考英语四级吗?还是 – 手机爱问...
  8. python支持函数式编程么_Python 函数式编程
  9. php如何设计自定义模型,php – Kohana ORM模型中的自定义方法
  10. Win7系统打开摄像头提示“请检查装置连接状况”怎么办