mysql主从复制

一、什么是主从复制?

1.用来建立一个和主数据库完全一样的数据库环境,称为从数据库。主数据库一般是准实时的业务数据库。在master中创建数据库,创建表,进行增删改操作都会被同步到所有slave中。

2.从库只能读数据,因为当从库写了数据positon会变化,且从库的版本要高于或等于主库。

二、主从复制的原理?

(1)主库db的更新事件(update、insert、delete)被写到binlog(binlog二进制文件记录了所有的sql语句);

(2)从库发起连接,连接到主库;

(3)主库创建binlog输出线程把binlog的内容发送到从库;

(4)从库启动之后,创建从库IO线程,读取主库传来的binlog内容,写到relaylog;

(5)创建从库的SQL线程,这个线程读取从库relaylog的更新事件并执行。

三、主从复制的作用?

1.数据的热备份,作为后备数据库,主数据库服务器故障后,可切换到从数据库继续工作,避免数据丢失;

2.读写分离;

3.实时灾备,用于故障切换。

四、其他问题

1.数据库的读的延迟问题了解吗?如何解决?

并行复制—-解决从库复制延迟的问题。

2.做主从后主服务器挂了怎么办?(将从库切换为主库)

(1)选pos最大的(一致性更高的)作为主库;

(2)使用半同步复制功能;

五、半同步复制、异步复制、全同步复制

1.异步复制(默认)

主库在执行完客户端提交的事务后会立即将结果返给给客户端,并不关心从库是否已经接收并处理。这样就会有一个问题,主如果crash掉了,此时主上已经提交的事务可能并没有传到从上,如果此时,强行将从提升为主,可能导致新主上的数据不完整。

2.全同步复制

指当主库执行完一个事务,所有的从库都执行了该事务才返回给客户端。性能上会收到影响。

3.半同步复制

(1)主库在执行完客户端提交的事务后不是立刻返回给客户端,,而是等待至少一个从库接收到并写到relay log中才返回给客户端。半同步复制最好在低延时的网络中使用。

(2)半同步复制存在哪些问题?(在得到从库确认的过程中,主库宕机了)

a.事务没发送到从库上:客户端会收到事务提交失败的信息,客户端会重新提交该事务到新的主上,当宕机的主库重新启动后,事务在从库中被提交了两次,一次是之前作为主的时候,一次是被新主同步过来的。

b.事务已经发送到从库上:从库已经收到并应用了该事务,但是客户端仍然会收到事务提交失败的信息,重新提交该事务到新的主上

(3)解决方案:(实现无数据丢失的半同步复制

MySQL 5.7引入了一种新的半同步方案:Loss-Less半同步复制。(“Waiting Slave dump”被调整到“Storage Commit”之前)

show status like 'Rpl_semi_sync_slave_status;监控主从是否运行在半同步复制模式下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL主从复制MySQL内建的复制功能,用于构建基于MySQL的大规模、高性能应用。它的主要目的是实现高性能、高可用性、可扩展性、灾难恢复、备份以及数据仓库等功能。主从复制的常见用途包括以下几种: 1. 数据备份和灾难恢复:通过将主服务器上的数据复制到一个或多个从服务器上,可以实现数据的备份和灾难恢复。当主服务器发生故障时,可以快速切换到从服务器来保证系统的可用性。 2. 负载均衡:通过将读操作分发到多个从服务器上,可以减轻主服务器的负载,提高系统的性能和可扩展性。 3. 数据分析和报表生成:通过将主服务器上的数据复制到一个或多个从服务器上,可以在从服务器上进行数据分析和报表生成,而不会影响主服务器的性能。 4. 数据分发:通过将主服务器上的数据复制到多个从服务器上,可以将数据分发到不同的地理位置或不同的应用程序中,以满足不同的需求。 在MySQL主从复制中,可以使用一些工具来简化配置和管理,比如MySQL-Proxy。MySQL-Proxy是MySQL官方开源项目,通过其自带的lua脚本进行SQL判断,但MySQL官方并不建议将MySQL-Proxy用于生产环境。此外,还需要在主服务器和从服务器上进行一些配置,如设置server-id、开启二进制日志、允许从服务器更新二进制日志等。还需要为从服务器授权复制权限,并通过show master status命令查看主服务器的状态信息。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [MySQL主从复制详细介绍](https://blog.csdn.net/qq_44590469/article/details/126340217)[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^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [MySQL主从复制](https://blog.csdn.net/m0_62473957/article/details/124140928)[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^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值