首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 主从同步方式

MySQL 主从同步方式

基础概念

MySQL 主从同步是一种数据库复制技术,通过这种技术可以将一个 MySQL 数据库服务器(主服务器)的数据复制到一个或多个其他 MySQL 数据库服务器(从服务器)。主服务器上的数据变更会被记录到二进制日志(Binary Log),从服务器通过读取这些日志并应用这些变更来保持与主服务器的数据一致性。

优势

  1. 读写分离:主服务器处理写操作,从服务器处理读操作,提高系统整体性能。
  2. 数据备份:从服务器可以作为数据备份,防止数据丢失。
  3. 高可用性:当主服务器出现故障时,可以快速切换到从服务器,保证服务的连续性。
  4. 负载均衡:通过多个从服务器分担读操作的压力,提升系统负载能力。

类型

  1. 异步复制:主服务器在执行完事务后立即返回结果给客户端,不等待从服务器确认。这是 MySQL 默认的复制方式。
  2. 半同步复制:主服务器在执行完事务后,必须等待至少一个从服务器确认收到并记录了事务的二进制日志后,才返回结果给客户端。
  3. 组复制:一种更高级的复制方式,允许多个主服务器组成一个复制组,组内的成员可以动态加入或离开,提供更高的可用性和数据一致性。

应用场景

  1. 读写分离:在高并发读取的场景下,通过主从同步实现读写分离,提升系统性能。
  2. 数据备份与恢复:通过从服务器进行数据备份,确保数据的安全性。
  3. 高可用架构:在关键业务系统中,通过主从同步实现高可用架构,防止单点故障。

常见问题及解决方法

  1. 主从不同步
    • 原因:可能是由于网络问题、主从服务器配置不一致、二进制日志损坏等原因导致。
    • 解决方法
      • 检查网络连接,确保主从服务器之间的网络通畅。
      • 检查主从服务器的配置,确保 server-idlog-bin 等配置一致。
      • 使用 mysqlbinlog 工具检查和修复二进制日志。
      • 重新同步数据,可以使用 mysqldump 工具备份主服务器数据并导入到从服务器。
  • 从服务器延迟
    • 原因:可能是由于从服务器性能不足、网络延迟、大事务处理等原因导致。
    • 解决方法
      • 提升从服务器的性能,增加硬件资源。
      • 优化网络配置,减少网络延迟。
      • 避免在主服务器上执行长时间运行的事务。
  • 主从切换失败
    • 原因:可能是由于从服务器数据不一致、主从服务器配置错误等原因导致。
    • 解决方法
      • 使用 pt-table-checksum 工具检查主从数据一致性。
      • 检查主从服务器的配置,确保 server-idrelay-log 等配置一致。
      • 使用 mysqlfailover 工具进行主从切换。

示例代码

以下是一个简单的 MySQL 主从同步配置示例:

主服务器配置(my.cnf)

代码语言:txt
复制
[mysqld]
server-id = 1
log-bin = /var/log/mysql/mysql-bin.log
binlog-do-db = mydatabase

从服务器配置(my.cnf)

代码语言:txt
复制
[mysqld]
server-id = 2
relay-log = /var/log/mysql/mysql-relay-bin.log
log-slave-updates = 1
read-only = 1

启动主从同步: 在主服务器上执行:

代码语言:txt
复制
CHANGE MASTER TO
MASTER_HOST='从服务器IP',
MASTER_USER='replication_user',
MASTER_PASSWORD='password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=107;
START SLAVE;

参考链接:

通过以上配置和操作,可以实现 MySQL 主从同步,提升系统的性能、可用性和数据安全性。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL 主从同步

为什么需要主从复制 分别读写数据库的时候,把读和写分开,能够有效的提高数据库的负载 保证数据的高可用,一旦有一台数据库服务器宕机,不会对数据产生太大的影响 可以横向扩展,实现数据库的水平扩容 主从同步的原理...主从复制的根本原理是从 master 服务器上面的数据,通过一定的方式同步到 slave 服务器上面。...上面的 3 个过程是 MySQL 主从同步的大概流程,其中 binlog 和 relay log 的读写都是顺序 IO,性能很高。...搭建主从同步 此处用 Linux 服务器进行演示: 安装 MySQL 修改 my.cnf 如果找不到 my.cnf文件可以直接新建一个文件,MySQL 会自动读取。...#同步的数据库的名称 重启 MySQL 服务 不同安装方式的重试方式不同,此处仅仅是一种可行的方式

5K30
  • Mysql主从同步

    所以在并发量高的情况下一般会使用主从同步来实现读写分离。本篇文章主要就是围绕主从同步实现读写分离这个主题去讲解。...我们其实在Redis专题中也有提到过主从同步的概念,现在我们可以先看下主从同步和读写分离的具体概念。...概念 主从同步:其实主从同步和Redis系列讲到的主从同步比较类似,在多个服务器部署Mysql服务,将其中一台Mysql服务设置为主数据库,其他的Mysql服务设置为从数据库,然后主从同步保证主从数据库数据的一致性...我们已经准备好两个centos服务器,现在我准备采用一主一从的方式实现主从同步: ip:49.235.28.88 /*设置成主数据库*/ ip:49.232.154.38 /*设置成从数据库*/ 主从同步配置思路...主从同步实现之后我们就可以在这个基础上实现数据库读写分离,减轻主数据库的负载。下一篇将着重介绍Mysql的读写分离。

    1.6K30

    mysql主从同步

    非常感谢大家昨晚来到我们的公开课课堂,一起探讨了关于数据库的架构,最后详细探讨学习了mysql主从同步的搭建过程。...今天分享一下昨晚的mysql数据库主从搭建的课堂笔记,让更多的人因为这次课程受益,另外我们每隔一段时间都会有相应的互动课程,大家可以前往https://ke.qq.com/course/254420#tuin...mysql主从复制中: 第一步:master记录二进制日志。在每个事务更新数据完成之前,master在二日志记录这些改变。MySQL将事务写入二进制日志,即使事务中的语句都是交叉执行的。...详细过程: 模式: C/S 模式 端口: 3306 x-63 主mysql服务器配置 创建要同步的数据库: mysql> create database bawei; mysql> use bawei...test1; +------+ | id | +------+ | 1 | +------+ 到现在为止mysql主从同步就搭建完成了,因为篇幅限制,后面会出现的问题解决方案暂时就不在这里阐述了

    3.9K20

    linux系统MySQL主从同步--使用binlog日志方式

    手机留言请访问:http://www.esqabc.com 复制方式 MySQL5.6开始主从复制有两种方式:基于日志(binlog)、基于GTID(全局事务标示符)。...(2)linux 系统的Mysql数据库(一个作为从数据库,注意:从数据库可以多个) ? 注意:同步的两个数据库版本一致,windows系统安装的MySql数据库命令有所不同。...## 设置server_id,一般设置为IP,注意要唯一,确保主从不相同 server_id=1 ## 复制过滤:也就是指定哪个数据库不用同步 binlog-ignore-db=mysql binlog-ignore-db...#sync_binlog 的默认值是0,像操作系统刷其他文件的机制一样,MySQL不会同步到磁盘中去而是依赖操作系统来刷新binary log。...,一般设置为IP,注意要唯一,确保主从不相同 server_id=2 ## 复制过滤:也就是指定哪个数据库不用同步 binlog-ignore-db=mysql binlog-ignore-db=information_schema

    1.5K30

    MySQL主从同步原理

    用途: 1、实施灾备,故障切换 2、读写分离 3、备份、避免数据丢失 条件: 1、主库开启binlog日志 2、主从服务器server-id不同 3、从库服务器能连通主库 方式: 1、同步复制...关于MySQL主从同步的一些问题 master的写操作,slaves被动的进行一样的操作,保持数据一致性,那么slave是否可以主动的进行写操作?...这样的话,相当于应用程序完成了SQL语句的路由,而且与MYSQL主从复制架构非常关联,一旦master挂了,某些slave挂了,那么应用程序就要修改了 能不能让应用程序与MYSQL主从复制架构没有什么太多关系呢...(谈到MySQL数据库主从同步延迟原理,得从mysql的数据库主从复制原理说起,mysql主从复制都是单线程的操作,主库对所有DDL和DML产生binlog,binlog是顺序写,所以效率很高;slave...,二是通过拦截方法名称的方式来决定主从的,如:save()、insert() 形式的方法使用master库,select()开头的使用slave库。

    1.9K20

    MySQL 主从同步配置

    一主一从同步,传统方式指定文件和位置同步 假设有mysql_1、mysql_2 ,1为master,2为slave,配置如下: master 端的配置文件中加入: server-id=1 log-bin...,则这个值为0,如果没有开启执行同步,则这个值在MySQL8中是NULL MySQL 配置互为主备同步,使用gtid 模式同步 假设 我们目标是 mysql_1 和 mysql_3 互为主备 在mysql...出现问题了 Could not find first log file name in binary log index file 我是这么处理的,因为是本地的新数据库,里面基本没数据,所以我就选择了粗暴的方式...就研究了下,怎么简单的配置主从设置,其实这块有很多细节。再生产环境中配置的话,需要深入的理解同步的机制,在出现同步问题的时候需要能够快速的解决。...问题:同步时跳过无法执行的GTID对应的事务 如果是修复主从复制中的异常,如果是在确认错误可以跳过的情况下,可以使用如下的方式: stop slave; set gtid_next='xxxxxxx:N

    2.5K10

    redis主从同步方式(redis数据同步原理)

    1.前言 在redis中为了保证redis的高可用,一般会搭建一种集群模式就是主从模式。...主从模式可以保证redis的高可用,那么redis是怎么保证主从服务器的数据一致性的,接下来我们浅谈下redis主(master)从(slave)同步的原理。...2.初次全量同步 当一个redis服务器初次向主服务器发送salveof命令时,redis从服务器会进行一次全量同步同步的步骤如下图所示: slave服务器向master发送psync命令(此时发送的是...4.重新复制 当slave断开重连之后会进行重新同步,重新同步分完全同步和部分同步 首先来看看部分同步大致的走向 当slave断开重连后,会发送psync 命令给master。...5.主从同步最终流程 6.结语 最近公司需要,我搭建了一套redis主从集群并且用哨兵进行监听实现主从切换。因此我根据《redis设计与实现》梳理了redis主从原理,给自己加深印象。

    4.4K30

    MySQL主从同步如何操作?

    主从同步优势 随着业务量的增长,高并发,数据库服务器宕机等问题频繁出现,单台MySQL服务器将会成为系统瓶颈。...为了解决此问题,通常会使用集群主从同步模式(Master-Slave)来同步数据,通过读写分离(MySQL-Proxy)来提升数据库的并发负载能力。...binlog MySQL主从之间数据同步主要通过 binlog 日志实现。...MySQL主从复制需要三个线程:master(binlog dump thread)、slave(I/O thread 、SQL thread) binlog dump线程: 主库中有数据更新时,...怎么减少主从延迟 主从同步问题永远都是一致性和性能的权衡,得看实际的应用场景,若想要减少主从延迟的时间,可以采取下面的办法: 优化SQL,避免慢SQL,减少批量操作,建议写脚本以update-sleep

    9910

    windows下mysql 主从同步

    今天先讲讲数据库的主从同步,两个好处:     一是读写分离可以用上。...比如 写操作就写到主数据库,读就从从数据库读取            二是纯粹给数据库备份,以防硬盘彻底崩了 主从数据库操作准备: 两台电脑,都安装好mysql 5.5及以上版本,最好两台电脑都安装同一版本数据库...    #二进制文件存放路径 binlog-do-db=test1    #待同步的数据库 保存并重启mysql服务后你可以在C:\Program Files\MySQL\MySQL Server 5.5...下找到my.ini文件,在其[mysqld] 下添加从服务器端配置: server-id=2    #服务器 id ,不能和主服务器一致 replicate-do-db=test1    #待同步的数据库...和107请替换为步骤三中查询出来的值 否则不会同步的)   ps:可能会报一个错误,大概的意思是说slave线程正在运行,不能设置,这样的话,执行mysql>stop slave; 停止slave线程,

    2K10

    Mysql配置 主从同步(上)

    一.准备 1.主从数据库版本最好一致 2.主从数据库内数据保持一致,若不一致,可将从库中所有数据删除,并将主库全部数据导入进去 主数据库:182.92.172.80 从数据库:123.57.44.85...二.操作 主数据库操作 1.开启binlog [mysqld] log-bin=mysql-bin #开启二进制日志 server-id=1 #设置server-id,和从不能一样 2.重启mysql,...创建用于同步的用户账号 systemc restart mysql 登陆数据库 mysql -hlocalhost -uname -ppassword 创建用户并授权:用户:test密码:123456,...privileges; 锁表,禁止写入,当前窗口不能退出,这时候开启另一个终端继续操作 flush table with read lock; 3.新窗口操作,查看master状态,记录二进制文件名(mysql-bin...Binlog_Do_DB | Binlog_Ignore_DB | +------------------+----------+--------------+------------------+ | mysql-bin

    1.4K21

    MySQL主从同步错误恢复

    MySQL主从同步集群在生成环境使用过程中,如果主从服务器之间网络通信条件差或者数据库数据量非常大,容易导致MySQL主从同步延迟。...MySQL主从产生延迟之后,一旦主库宕机,会导致部分数据没有及时同步至丛库,重新启动主库,会导致丛库与主库同步错误,如何快速恢复主从同步关系呢,如下有两种方法: 1、忽略错误后,继续同步(只有一次错误)...slave; 2、重新做主从同步,完全同步:(主从数据差别大) 此种方法适用于主从库数据内容相差很大,或者要求数据完全统一的情况,数据需完全保持一致。...备份文件传到从库机器,进行数据恢复: scp mysql.sql root@10.6.97.134:/tmp/ 5)停止从库的状态,导入数据备份 mysql> stop slave; mysql> source.../tmp/mysql.sql; 6)设置从库同步,并开启slave; change master to master_host = '10.6.97.133', master_user =  'tongbu

    2.1K10

    Mysql主从同步架构配置

    一、mysql主从介绍: MySQL主从又叫做Replication、AB复制。简单讲就是A和B两台机器做主从后,在A上写数据,另外一台B也会跟着写数据,两者数据实时同步的。...也就是说,当你在A机器写入一个表,再次查看B机器也会同步一个表。 1.1 MySQL主从是基于binlog的,主上须开启binlog才能进行主从。...主从过程大致有3个步骤: 主将更改操作记录到binlog里。 从将主的binlog事件(sql语句)同步到从本机上并记录在relaylog里。...我们先同步一下,让主从的数据保护一致。然后才可以实现主从实时同步。...3.8 到主服务器(zhdy-03)执行恢复写操作: mysql> unlock tables; Query OK, 0 rows affected (0.00 sec) 四、测试主从同步 4.1 主服务器上

    3.7K90

    Docker安装 Mysql主从同步

    主从同步 1、MySQL主从同步原理 基本原理: slave会从master读取binlog来进行数据同步 具体步骤: step1:master将数据改变记录到二进制日志(binary log)中。...2、一主多从配置 服务器规划:使用docker方式创建,主从服务器IP一致,端口号不一致,配置前先把相关端口开放 主服务器:容器名mysql-master,端口3306 从服务器:容器名mysql-slave1...STATEMENT:日志记录的是主机数据库的写指令,性能高,但是now()之类的函数以及获取系统参数的操作会出现主从数据不同步的问题。...2.4、实现主从同步 在主机中执行以下SQL,在从机中查看数据库、表和数据是否已经被同步 CREATE DATABASE db_user; USE db_user; CREATE TABLE t_user...此错误,虽然不影响主从同步的搭建,但是如果想从远程客户端通过以下方式连接docker中的MySQL则没法连接 C:\Users\administrator>mysql -h 192.168.100.201

    1.3K20
    领券