MySQL——主从复制相关

主从复制

概述

指讲主数据库的DDL和DML操作通过二进制日志传到从库服务器中,然后在从库上对这些日志重新执行(也叫重做),从而使得从库和主库的数据保持同步
mysql支持一台主库同时向多台从库进行复制,从库同时也可以作为其他从服务器的主库,实现链状复制。
MYSQL复制的优点主要包含以下三个方面:

  1. 主库出现问题,可以快速切换到从库提供服务
  2. 实现读写分离,降低主库的访问压力
  3. 可以在从库中执行备份,以避免备份期间影响主库服务
    MySQL——主从复制相关_第1张图片

原理

复制分为三步:

  1. Master主库在事务提交时,会把数据变更记录在二进制日志文件Binlog中
  2. 从库读取主库的二进制日志文件Binlog,写入到从库的中继日志Relay log
  3. slave重做中继日志中的时间,将改变反映它自己的数据

MySQL——主从复制相关_第2张图片

搭建

服务器准备开放制定端口或关闭服务器防火墙

#开放制定3306端口
firewall-cmd --zone=public add-port=3306/tcp -permanent
firewall-cmd -reload
#关闭服务器的防火墙
systemctl stop firewalled
systemctl disabled firewalled

主库配置

1.修改配置文件/etc/my.cnf

#mysql服务id,保证整个集群环境中唯一,取值范围:1-2^32 - 1,默认为1
server-id=1
#是否只读,1 只读,0读写
read-only=0
#忽略的数据,指不需要同步的数据库
#binlog-ignore-db=mysql
#指定同步的数据库
#binlog-do-db=db01

2.重启mysql
3. 登录mysql,创建远程连接的账号,并授予主从复制权限

#创建用户,并设置密码,该用户可在任务逐级连接mysql服务
CREATE USER 'lixiaolang'@'%'IDENTIFIED WITH mysql_native_password BY 'Root@123456'
#为用户分配主从复制权限
GRANT REPLICATION SLAVE ON *.* 'lixiaolang'@'%'
  1. 通过指令,查看二进制日志坐标
    show master statusl
    字段含义说明:
    file: 从那个日志文件开始推送日志文件
    position:从那个位置开始推送日志
    binlog_ignore_db:制定不需要同步的数据库

从库配置

1.修改配置文件 /etc/my.cnf

#mysql服务id,保证整个集群环境中唯一,取值范围:1-2^32-1,和主库不一样即可
server-id=2
#是否只读,1代表只读, 0代表读写(只针对普通用户)
read-onlu=1
#针对超级管理员也为只读
super-read-only=1
  1. 重启mysql服务
  2. 登录mysql,这只主库配置
CHANGE REPLICATION SOURCE TO SOURCE_HOST='XXX.XXX',SOURCE_USER='xxx',SOURCE_PASSWORD='xxx',SOURCE_LOG_FILE='xxx',SOURCE_LOG_POS='xxx';
上述是8.0.23中的语法,若为之前的版本择如下sql
CHANGE MASTER TO MASTER_HOST='xxx.xxx.xxx.xxx', MASTER_USER='xxx',MASTER_PASSWORD='XXX',MASTER_LOG_FILE='XXX',MASTER_LOG_POS='XXX';
  1. 开启同步操作
start replica; #8.0.22之后
start slave; #8.0.22之前
  1. 查看主从同步状态
show replica status;
show slave status;

分库分表

介绍
随着互联网及移动互联网的发展,应用系统的数据量也是成指数增长若采用单数据库进行数据存储,存在一下性能瓶颈

  1. IO瓶颈:热点数据太多,数据库缓存不足,产生大量磁盘IO,效率较低,请求数据太多,贷款不够,网络IO瓶颈
  2. CPU瓶颈:排序、分组、连接查询、聚合统计等SQL会耗费大量cpu资源。请求数太多,CPU出现瓶颈
    分库分表的中心思想就是将数据分散存储,使得单一数据库/表的数据量变小来缓解单一数据库的性能问题,从而达到提升数据库性能的目的

拆分策略

垂直分库

以表为依据,根据业务不同将不同表拆分到不同库里
特点:

  1. 每个库的表结构都不一样
  2. 每个库的数据页不一样
  3. 所有库的并集是全量数据

MySQL——主从复制相关_第3张图片

垂直分表

以字段为依据,根据字段属性将不同字段拆分到不同表中
特点

  1. 每个表的结构都不一样
  2. 每个表的数据页不一样,一般通过一列关联
  3. 所有表的并集是全量数据

MySQL——主从复制相关_第4张图片

水平分库

以字段为依据,按照一定策略,讲一个库的数据拆分到多个库中
特点:

  1. 每个库的表结构都一样
  2. 每个库的数据都不一样
  3. 所有库的并集是全量数据

MySQL——主从复制相关_第5张图片

水平分表

以字段为依据,按照一定策略,将一个表的数据拆分到多个表中
特点:

  1. 每个表的表结构都一样
  2. 每个表的数据都不一样
  3. 所有表的并集是全量数据

实现技术

MySQL——主从复制相关_第6张图片
shardingJDBC:基于AOP原理,在应用程序中对本地执行的SQL进行拦截,解析、改写、路由代理。需要自行编码配置实现,只支持java语言,性能较高
MyCat:数据库分库分表中间件,不用调整代码即可实现分库分表,支持多种语言,性能不及前者
MySQL——主从复制相关_第7张图片

MyCat

mycat是开源的、活跃的、基于Java语言编写的mysql数据库中间件,可以像使用mysql一样来使用mycat,对于开发人员来说根本感觉不到mycat的存在
优势:

  1. 性能可靠稳定
  2. 强大的技术团队
  3. 体系完善
  4. 社区活跃
    下载地址: http://dl.mycat.org.cn/n

概念介绍

MySQL——主从复制相关_第8张图片

读写分离

简单的说是把对数据库的读和写操作分开,以对应不同的数据库服务器。主数据库提供写操作,从数据库提供读操作,这样能有效的减轻单台数据库的压力。
通过MyCat即可实现上述功能,不仅可以支持mysql,也可以支持oracle和sqlserver
MySQL——主从复制相关_第9张图片
MySQL——主从复制相关_第10张图片

双主双从

一个主机Master1用于处理所有写请求,它的丛集Slave1和另一个Slave2负责所有读请求,当Master主机宕机后,Master主机负责写请求,Master1、Master2互为备机
MySQL——主从复制相关_第11张图片

你可能感兴趣的:(MySql,数据库,学习)