IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MySQL主从复制 -> 正文阅读

[大数据]MySQL主从复制

MySQL主从复制

当我们的业务越来越来越庞大的时候,如果是单个MySQL服务器的情况下,负载过重的时候就容易造成服务宕机,这个时候我们该怎么解决呢?可以使用MySQL自带的主从复制(主服务器负责写,从服务器负责读),可以帮助我们实现负载均衡和读写分离。

主从复制分为:

  • 主从同步:用户写入数据时当主服务器和从服务器同步了才告诉用户写入成功,等待时间较长
  • 主从异步:只要用户访问了主服务器,立刻返回成功
  • 主从半同步:用户写入数据时只要主服务器和其中一个从服务器同步就返回成功

1.一主一从

在这里插入图片描述

2.一主多从

在这里插入图片描述

一主多从是目前最多的主从架构,实现了HA(高可用),也可以读写分离

3.多主一从

在这里插入图片描述

多主一从可以将多个MySQL数据可备份到一个性能好的从服务器上

4.双主复制

双主复制

类似于主从复制,每个master既是master,又是另外一台服务器的slave(既当爹又当娘),每一方做的变更,也会同步到另一方的数据库中。

5.级联复制

在这里插入图片描述

部分slave不连接主节点,而是连接从节点,如果主节点有太多的从节点,会损耗部分性能用于复制数据,我们可以让部分从节点连接主节点,部分从节点连接从节点,这样可以缓解主节点的压力,并且不影响数据一致性。

6.复制原理

MySQL主从复制是基于主服务器在binlog中记录了所有对数据库的更改(insert,update,delete,create/alter/drop table, grant 等等),因此要进行复制,必须在主服务器上启用binlog

主从复制的原理其实就是把主服务上的binlog日志复制到从服务器上执行一遍,这样从服务器上的数据就和主服务器上的数据同步了。

7.工作过程

1.从库会生成两个线程,一个IO线程,一个SQL线程

2.IO线程会去请求主线程的binlog,并将得到的数据写到Relaylog(中继日志)中。

3.主库会生成一个log dump thread,用于给从库IO thread 传输binlog。

4.从库的SQL线程会读取Relaylog(中继日志)的数据,并解析成具体操作,来实现主从的最终数据一致。

在这里插入图片描述

8.配置一主一从

主库配置, Linux 配置下是/etc/my.cnf,windows是my.ini文件

我的主服务器是部署在阿里云上,从服务器在本地,需要注意阿里的安全策略以及服务器的防火墙

主服务器

[mysqld]
    # 根目录
    basedir = /usr/local/mysql
    # 数据目录
    datadir = /usr/local/mysql/data
    # 主机服务器唯一id,主从环境下必须配置且唯一
    server-id = 1103
    # 免密登录,当忘记密码后可以使用
    #skip-grant-tables
    #default_authentication_plugin=mysql_native_password
    # binarylog,二进制日志文件位置,主从必须配置
    log-bin = /usr/local/mysql/data/mysqlbin
    # errorlog,错误日志
    log-error = /usr/local/mysql/data/mysql
    # 当mysql主从版本不一致的时候(一般来说主版本低)
    binlog-checksum = none
    socket = /usr/local/mysql/mysql.sock
    character-set-server=utf8
    # 表名不区分大小写(linux下默认区分,windows默认不区分),但需要注意的是linux环境下mysql在8.0以上版本必须在初始化时就进行设置
    lower_case_table_names=1
    port = 3306
    sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
 [client]
   socket = /usr/local/mysql/mysql.sock
#mysql 8.0 以下
#第一个*代表数据库名,第二个*代表表名,*代表任意,zhangsan为创建给从库的用户,从库ip可以用具体ip,也可以用%代表任意,password 为创建的 用户密码
grant replication slave on *.* to 'zhangsan'@'从库IP' identified by 'password';
# 刷新配置
flush privileges;
# mysql 8.0以上
# mysql 8 以上必须先创建用户再进行授权
CREATE USER 'zhangsan'@'从库ip' IDENTIFIED BY 'password';
GRANT  REPLICATION SLAVE ON  *.* TO 'zhangsan'@'%'
flush privileges;

我们平时可以用一些命令来查看主从的状态

#查看主状态
show master status;
#查看从状态
show slave status;



# 在cmd下或者linux 下可以使用
show master\G

show slave\G

从服务器

# 我们只需要添加这些即可
server-id = 1
log-bin = C:/ProgramData/MySQL/MySQL Server 8.0\Data\binlog
# 连接主库
CHANGE MASTER  TO  MASTER_HOST='主服务Ip'
#上面配置的用户名和密码
MASTER_USER=‘zhangsan’
MASTER_PASSWORD='password'
# 可以在主服务下通过show master status; 或者 show master\G 查看 File 和 Position
MASTER_LOG_FILE='File', MASTER_LOG_POS=Position;

配置完之后

# 启动主从
start slave;
# 停止主从
stop slave;

当启动后我们通过 show slave status;查看状态,如果Slave_IO_RunningSlave_IO_Running都是YES,那么恭喜你配置成功了。

9.异步复制

一个主库,对应多个或者单个从库,数据异步的同步到从库。

在这里插入图片描述

异步复制模式下,主节点不会主动推送数据到从节点,主库在处理完客户端提交的事务后会立即将结果返回给客户端,并不关心从库是否接收并处理,但这样也面临着风险,如果主节点崩溃,如果强行将从库提升为主,可能会导致数据不一致。

10.同步复制

MySQL cluster 中特有的复制方式。

当主库执行完一个事务,然后所有的从库都复制了该事务并成功执行完才返回成功信息给客户端,性能较低

11.半同步复制

在异步复制的基础上,确保主库上的事务在提交之前至少有一个从库已经收到该事务并执行完成。

在这里插入图片描述

介于异步复制和全同步复制之间,主库在执行完客户端提交的事务后不是立刻返回给客户端,而是等待至少一个从库接收到并写到 relay log 中才返回成功信息给客户端(只能保证主库的 Binlog 至少传输到了一个从节点上),否则需要等待直到超时时间然后切换成异步模式再提交

半同步模式不是 MySQL 内置的,从 MySQL 5.5 开始集成,需要 master 和 slave 安装插件开启半同步模式。

12.延迟复制

在异步复制的基础上,设置主库和从库的数据同步延迟时间,保证数据同步最少是这个时间。

13.mysql的复制方式

13.1 基于语句的复制

基于语句的复制模式下,主库会记录那些造成数据更改的查询,当备库读取并重放这些事件时,实际上只把主库上执行过的SQL再执行一遍。这种方式简单,二进制文件小,传输带宽占用小,但是语句更新依赖于某些因素,例如时间戳,所以一般我们应该在代码的层面做好处理,而不是在MySQL中。

  • 传输效率高,减少延迟。
  • 在从库更新不存在的记录时,语句赋值不会失败。而行复制会导致失败,从而更早发现主从之间的不一致。
  • 效率高,语句复制一行解决的问题行复制可能得成百上千万行
13.2 行数据复制

MySQL5.1开始支持基于行的复制,这种方式会将实际数据记录在二进制日志中。这样导致复制的压力比较大,日志占用的空间大,传输带宽占用大。但是这种方式比基于语句的复制要更加精确。

13.3 混合复制

MySQL默认情况下使用的是基于语句的复制方式,但如果发现语句无法呗正确地复制,就切换基于行的复制模式

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-05-24 18:15:37  更:2022-05-24 18:18:17 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 3:58:11-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码