Mysql架构篇--Mysql(M-S) 主从同步


前言:


一、主从同步是什么?

MySQL主从同步(MySQL Replication)是MySQL服务器的一个常用特性,它能够将MySQL服务器数据自动同步到其他MySQL服务器上,从而实现数据备份和负载均衡的功能。在实际应用中,MySQL主从同步可以用于实现高可用、灾备转移、读写分离等。

二、主从同步实现:

1.准备工作:

  • 首先需要有大于等于2个的mysql 实例,一个作为master,其它的作为slave;

2.开启主从复制:

2.1 mysql 服务端配置文件修改:

  • 作为master 的节点需要在配置文件中开启binlog,代码如下:
# log-bin 开启binlog 日志,master-log 为记录日志的文件前准名字
log-bin=master-log
# master 的服务节点唯一id
server-id=1
# 可选参数配置哪些数据库是需要被同步的
binlog-do-db=rep
binlog-do-db=user
# 可选参数配置哪些数据库是不需要被同步的
binlog-ignore-db=mysql
binlog-ignore-db=test
# 此处演示使用配置使用旧的密码方式进行数据传输,因为mysql8 默认已经按照ssl 进行加密传输了
default_authentication_plugin=mysql_native_password
  • 作为slave 的节点,配置节点id,代码如下:
server-id=2
default_authentication_plugin=mysql_native_password

配置完成记得重启master和slave mysql 的服务

2.2 mysql master 节点用户创建:

-- 创建slave_rep 用户,密码是123456,可以被连接的ip 段是192.168.75
CREATE USER 'slave_rep'@'192.168.75.%' IDENTIFIED BY '123456';  
-- 对创建的用户赋予复制权限
GRANT REPLICATION SLAVE ON *.* TO 'slave_rep'@'192.168.75.%';

2.3 mysql slave 节点开启数据复制:

  • 在master 节点查看状态:
show master status;

在这里插入图片描述

  • slave 节点设置数据同步节点:
change master to master_host='192.168.75.128',master_user='slave_rep',master_password='123456', master_port=3306,
master_log_file='master-log.000002', master_log_pos=340

其中,master_ip_address是主服务器的IP地址,username和password是用于同步的用户名和密码,master-log.000002和340是主服务器上二进制日志文件的名称和位置,需要根据实际情况修改。

  • slave 启动主从同步:
start slave;
  • slave 查看主从同步状态:
show slave status ;

在这里插入图片描述

如果发现 Slave_IO_Running和Slave_SQL_Running都显示为Yes,说明配置MySQL主从成功。 但凡有一个不是Yes,是什么Connecting,No之类的,说明没配置成功。


  • 配置成功后,在master 创建允许同步的数据库,修改数据都会被同步到slave 节点;

3.新加入slave的节点如何开启主从复制:

对于已经存在的主从同步 节点,现在如果要在增加一个slave 从节点;

3.1 slave 从节点设置节点id:

server-id=3
default_authentication_plugin=mysql_native_password

配置完成记得重启 mysql 服务

3.2 在slave节点新建数据库:

注意和master节点中要同步的数据库名称保持一致

3.3 在slave节点还原数据库:

将master 下要同步得数据数据全量备份后,还原到slave 节点的对应的数据库中

3.4 开启主从同步:

步骤同 2.3 mysql slave 节点开启数据复制:相同

三、主从同步原理:

1.binlog 日志:

binlog 记录了对于数据操作的ddl 和dml 语句,这些语句是可以直接执行;

2.binlog 日志记录:

2.1 日志记录格式:

在 MySQL 8 中,binlog-format 参数已经被弃用,被 default_binlog_format 参数所取代。在 MySQL 8 中,如果未显式指定二进制日志的格式,default_binlog_format 参数将控制 MySQL 记录二进制日志的格式。
default_binlog_format 参数有以下可选值:

  • ROW:记录行级别别更改。在 MySQL 8 中,这是默认的二进制日志格式。
  • STATEMENT:记录每个需要记录的 SQL 语句。
  • MIXED:混合使用 ROW 和 STATEMENT 两种格式,选择使用哪一种格式取决于具体的 SQL 语句。

2.2 三种记录格式的区别:

  • 基于语句级别的复制(statement-based replication,SBR):这种方式是最初的复制方式,将主服务器上执行的修改数据的SQL语句记录到二进制日志文件中,然后将这些SQL语句发送到从服务器,从服务器再执行这些SQL语句完成数据同步。此方法的优点是复制过程中只传输SQL语句,网络传输量小;缺点是可能会有一些数据不一致的情况出现,例如在主服务器上执行的一些非确定性函数(如 uuid,date 等),或者在从服务器上存在不存在的表或数据行。

  • 基于行级别的复制(row-based replication,RBR):这种方式是在SBR基础上发展而来,它直接将修改数据的二进制数据发送到从服务器,然后在从服务器上执行相同的二进制数据完成数据同步。此方法的优点是能够保证数据一致性,能够处理一些复杂的SQL语句;缺点是对于大量的操作,可能会产生大数据量传输。

  • 基于混合复制(mixed-based replication,MBR):它是综合了SBR和RBR两种方式的优点,即在不同的情况下选择不同的方式。例如,对于不涉及大量数据变更的SQL语句使用语句级别的方式,对于大量数据变更的SQL语句使用行级别方式。该方式比较灵活,能够平衡性能和数据一致性的关系。

需要注意的是,建议在配置主从复制时明确指定二进制日志的格式,以避免误解和不必要的问题。在一致性设置和数据同步方面,明确定义二进制日志格式可以提高主从数据同步的效率和稳定性。

2.3 binlog 主从复制流程:

在这里插入图片描述

  • slave 节点先发送请求给到主节点,主节点在有数据变化时就可以推送数据给到 从节点;
  • 从节点接到数据后先写到log 中,然后在由其它的线程对log 数据进行解析然后入库;

四、总结:

Mysql 主从同步主要是通过master 节点开启binlog 日志,然后slave 节点消费binlog 日志的数据,将数据更新到各自的库中。

  • 0
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Cesium使用Primitive(图元)来进行绘制和渲染。Primitive是Cesium中的一个类,用于定义几何图形的创建和渲染方式。根据引用和引用的示例,可以看到几种使用Primitive的方法。 首先,通过创建一个GeometryInstance实例,并指定几何形状的类型和参数,可以创建一个Primitive对象。例如,在引用中使用WallGeometry创建了一个墙体几何图形的Primitive。 其次,可以使用PrimitiveCollection来创建一个图元集合,然后通过添加不同的图元实例来构建图形。例如,在引用中使用PointPrimitiveCollection添加了两个点图元,并设置了位置和颜色。 此外,Cesium还提供了两种绘制几何图形的方式:通过Entity和Primitive。通过Entity方式,可以使用viewer.entities.add方法创建一个Entity对象,并在其中定义几何图形的属性和材质。例如,在引用中使用RectangleGeometry和StripeMaterialProperty创建了一个矩形图形的Entity。 通过Primitive方式,可以创建一个GeometryInstance对象,并指定几何形状和外观属性,然后将其添加到scene.primitives中。例如,在引用中使用RectangleGeometry和EllipsoidSurfaceAppearance创建了一个矩形图形的Primitive。 综上所述,Cesium使用Primitive来定义和渲染几何图形,可以通过不同的方法和参数来创建和添加不同类型的图元实例。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [VUE3-Cesium(Primitive详解)](https://blog.csdn.net/damadashen/article/details/125291834)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Cesium开发高级 | 01空间数据可视化之Primitive](https://blog.csdn.net/ls870061011/article/details/122748411)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值