环境:MySQL5.7,VMware-Workstation-12-Pro,Windows-10,CentOS-7.5,Xshell5

1. 基本概念和操作思路

主从复制能做什么

数据库的主从复制,是一台主数据库机器(Master)把自己的数据,复制到一台或多台从机器(Slaves)上。主从机器的通信方式是基于TCP/IP协议的。数据库最简单,也是直接就能实现的功能就是对数据库进行实时备份,如果不额外配置情况下没有其它功能,主数据库挂了,集群还是直接瘫痪除非手动把数据库连接信息切换到从数据库机器上,也就是说不能实现故障切换。不额外配置对数据库性能也没有提升,读写操作都用的是主数据库的计算资源,从数据库仅仅是增量同步主数据库。

但是数据库的高可用(故障切换)和读写分离(写走主,读负载到多台从),是基于数据库主从复制之上才能搭建起来的,本文介绍的是数据库主从复制的实现。

基本实现原理

数据库的主从复制有几种实现方案,这里介绍的基于二进制日志(binary log)来实现主从复制,原理很简单,就是主数据库开启日志记录功能,这样在主数据库上进行的操作都会被记录到这个日志里,然后从数据库通过网络连接到数据库,利用这份二进制日志,把相关操作在从机器上再执行一遍,从而实现数据库同步。

操作步骤概况

首先考虑一下实际环境,假设我们已经有一台数据库机器,这台数据库机器是对外提供WEB服务的,比如是LAMP架构里的一员。我们知道数据库是非常重要的,代码丢了还能重写,用户数据丢了,公司距离倒闭也就不远了,因此为了稳妥我们有必要考虑下数据库的安全性问题。只有一台数据库机器时,基本上重点考虑数据不能丢,但是部署主从复制时,至少需要两台机器,也就是还需要考虑数据一致性的问题。

力求稳妥,我们在搭建数据库主从复制时,尽可能避免在这期间操作主数据库,尤其时不能进行写相关操作,搭建完毕之后,最好不要单独对从数据库做写相关操作,以防数据不一致的问题。从数据库只能用来读,比如对数据进行统计分析时,我们就可以到从数据库读数据,从而缓解主数据库的压力。

搭建数据库主从复制,具体步骤如下:

  1. 启用主数据库二进制日志记录功能
  2. 在主数据库上创建用户以供从数据库远程连接
  3. 备份主数据库数据
  4. 把数据库备份导入到从数据库上
  5. 配置从数据库连接主数据库
  6. 启用从数据库,使其进入SLAVE状态

下面我启两台虚拟机,分别作为主数据库(172.16.1.51)和从数据库(172.16.1.52),演示如何搭建数据库主从复制。具体环节如下:

[root@master ~]# hostname -I
10.0.0.51 172.16.1.51
[root@slave ~]# hostname -I
10.0.0.52 172.16.1.52

51机器是LAMP架构的一员,上面已有供给其它WEB集群使用的数据,而52是全新机器。

2. MASTER-配置

  1. 启用Master二进制日志记录功能

    [root@master ~]# systemctl stop mysqld
    [root@master ~]# /etc/my.cnf
    [root@master ~]# egrep -v '^$|^#' /etc/my.cnf
    [mysqld]
    datadir=/var/lib/mysql
    socket=/var/lib/mysql/mysql.sock
    symbolic-links=0
    log-error=/var/log/mysqld.log
    pid-file=/var/run/mysqld/mysqld.pid
    log-bin=mysql-bin #+
    server-id=1 #+
    [root@master ~]# systemctl start mysqld

    更改数据库配置文件,最好先停后启。/etc/my.cnf是MySQL的配置文件,在其中的mysqld区块中增加如上最后两行内容,即可启用二进制日志记录功能,=mysql-bin是可以省略不写的,mysql-bin是表示日志文件名的前缀,可换成其它。只要涉及到多台MySQL机器协同工作,那么每台机器都需要一个ID来标识,server-id就是这个作用,不能重复。

  2. 为从机器创建远程连接用户

    [root@master ~]# mysql -uroot -pAs4k.top
    mysql> CREATE USER 'repl'@'%' IDENTIFIED BY 'As4k.top';
    mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';

    上述操作就是,授权rpel用户,密码为As4k.top,对所有数据库都具有REPLICATION权限。

  3. 拿到Master状态信息(从连接主时用)

    从这一步开始,最好不要再动主数据库了,但是还不能把mysqld服务直接停掉,可以把数据库的表锁定只能读取,我还把WEB集群上的nginx和php都停掉,彻底杜绝任何操作数据库的可能性。

    mysql> FLUSH TABLES WITH READ LOCK;
    mysql> SHOW MASTER STATUS;
    +------------------+----------+--------------+------------------+-------------------+
    | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +------------------+----------+--------------+------------------+-------------------+
    | mysql-bin.000003 | 154 | | | |
    +------------------+----------+--------------+------------------+-------------------+
    1 row in set (0.00 sec)

    File表示当前二进制文件名,Position表示位置,在进行数据库写入操作时,这两个值都是会变化的,就是用来告诉从数据库从什么位置开始复制。

  4. 使用mysqldump备份整个数据库

    [root@master ~]# mysqldump -uroot -pAs4k.top --all-databases --master-data > /root/dbdump.db
    [root@master ~]# scp /root/dbdump.db root@172.16.1.52:/root

    --all-databases备份所有数据库,--master-data给slave机器识别用的。

  5. 解锁数据库

    [root@master ~]# mysql -uroot -pAs4k.top -e "UNLOCK TABLES;"

3. SLAVE-配置

  1. MySQL5.7社区版并改密码(官方源)

    [root@slave ~]# yum install mysql-community-server -y
    [root@slave ~]# systemctl start mysqld
    [root@slave ~]# systemctl enable mysqld
    [root@slave ~]# mysql -uroot -p$(awk '/temporary password/ {print $NF}' /var/log/mysqld.log) \
    --connect-expired-password -e "ALTER USER 'root'@'localhost' IDENTIFIED BY 'As4k.top'";
  2. 设置一个ID(显然需要"与众不同")

    [root@slave ~]# systemctl stop mysqld
    [root@slave ~]# vim /etc/my.cnf
    [root@slave ~]# egrep -v '^$|^#' /etc/my.cnf
    [mysqld]
    datadir=/var/lib/mysql
    socket=/var/lib/mysql/mysql.sock
    symbolic-links=0
    log-error=/var/log/mysqld.log
    pid-file=/var/run/mysqld/mysqld.pid
    server-id=2 #+
    [root@slave ~]# systemctl start mysqld
  3. 设置Slave连接Master

    mysql> CHANGE MASTER TO
    MASTER_HOST='172.16.1.51',
    MASTER_USER='repl',
    MASTER_PASSWORD='As4k.top',
    MASTER_LOG_FILE='mysql-bin.000003',
    MASTER_LOG_POS=154;

    IP,账号,密码这都是显而易见的,FILE和POS是在主机器上使用SHOW MASTER STATUS得到的。

  4. 把Master数据导入Slave

    [root@slave ~]# mysql -uroot -pAs4k.top < /root/dbdump.db
  5. 启动Slave线程

    [root@slave ~]# mysql -uroot -pAs4k.top -e "START SLAVE"

    暂停使用STOP SLAVE

4. 检查与测试

查看主从的状态

查看主

[root@master ~]# mysql -uroot -pAs4k.top -e "SHOW MASTER STATUS"

查看从

[root@slave ~]# mysql -uroot -pAs4k.top -e "SHOW SLAVE STATUS\G"
mysql: [Warning] Using a password on the command line interface can be insecure.
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 172.16.1.51
Master_User: repl
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000003
Read_Master_Log_Pos: 154
Relay_Log_File: slave-relay-bin.000002
Relay_Log_Pos: 320
Relay_Master_Log_File: mysql-bin.000003
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
.......

除了IP,端口,账号这些要和主数据库对上,位置信息也要对上,这样才能保证数据的一致性。

测试效果

测试很简单,在Master上做一些写入数据库的操作,然后到Slave机器上查看是否正确同步即可。这里不在赘述。

作者:阿胜4K

出处:https://www.cnblogs.com/asheng2016/p/replication-for-backup.html

MySQL主从复制(Replication for Backup)的更多相关文章

  1. MySQL主从复制(Replication)(MySQL数据同步)配置

    MySQL是开源的关系型数据库系统.复制(Replication)是从一台MySQL数据库服务器(主服务器master)复制数据到另一个服务器(从服务器slave)的一个进程. 配置主服务器(mast ...

  2. Linux MySQL主从复制(Replication)配置

    MySQL是开源的关系型数据库系统.复制(Replication)是从一台MySQL数据库服务器(主服务器master)复制数据到另一个服务器(从服务器slave)的一个进程. 配置主服务器(mast ...

  3. mysql主从复制replication的一些相关命令

    主服务器上的相关命令:show master status; mysql> show master status\G . row *************************** Posi ...

  4. centos5.4下mysql主从复制

    centos5.4下mysql主从复制配置分享. 本文转自:http://www.jbxue.com/article/771.html 安装环境:centos 5.4 mysql版本:mysql 5. ...

  5. 搭建mysql主从复制---Mysql Replication

    主从复制原理 Mysql的Replication是一个异步的复制过程,从一个Mysql Instance(master)复制到另一个Mysql Instance(slave).中间需要三个线程slav ...

  6. 配置MySQL主从复制报错Last_IO_Error: Fatal error: The slave I/O thread stops because master and slave have equal MySQL server ids; these ids must be different for replication to work

    配置MySQL主从复制报错 ``` Last_IO_Error: Fatal error: The slave I/O thread stops because master and slave ha ...

  7. mysql主从复制操作步骤

    注: .做主从复制的两台服务器server-id不能相同 .主从的字符集要一样,不然数据导入会报错 .开启db01的log-bin功能 [root@db01 mysql]# vim /etc/my.c ...

  8. mysql主从复制配置

    使用mysql主从复制的好处有: 1.采用主从服务器这种架构,稳定性得以提升.如果主服务器发生故障,我们可以使用从服务器来提供服务. 2.在主从服务器上分开处理用户的请求,可以提升数据处理效率. 3. ...

  9. [转]MySQL主从复制原理介绍

    MySQL主从复制原理介绍 一.复制的原理 MySQL 复制基于主服务器在二进制日志中跟踪所有对数据库的更改(更新.删除等等).每个从服务器从主服务器接收主服务器已经记录到其二进制日志的保存的更新,以 ...

随机推荐

  1. python下安装Scikit-learn

    安装SK-Learn需要依赖的Python安装包有: Python (>= 2.6), NumPy (>= 1.3), SciPy (>= 0.7), 下载python的各种包的地址 ...

  2. IOS设计模式第三篇之外观设计模式

    外观设计模式: 这个外观设计模式提供了一个单独的接口给复杂的子系统.而不是暴露用户的一组类和API,你仅仅暴露一个简单的同一的API. 下面的图片解释这个概念: API的用户根本不知道后面系统的复杂性 ...

  3. 五、K3 WISE 开发插件《K3 Wise 群发短信配置开发(二)之短信群发配置》

    开发环境:K/3 Wise 13.0.Sql Server 2005 目录 一.开启Sql Server Agent代理服务 二.短信发送原理 三.编写存储过程 四.开启Sql Server作业 一. ...

  4. OpenStack Networking – FlatManager and FlatDHCPManager

    最好的分析FlatDHCPManager的源文,有机会把这篇翻译了 =========================== Over time, networking in OpenStack has ...

  5. 为Docker容器中运行的gitlab添加ssh的一些问题记录

    最近做的一个东西,是将gitlab10.x的汉化版本,从源码编译(在源码中自己定制一些东西),然后制作成Docker镜像,作为Docker容器来运行 在启用容器中的gitlab的ssh的时候,遇到了一 ...

  6. .net C#中页面之间传值传参的六种方法

    1.QueryString是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中.如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法.但是对于传递数组或对象的话,就不能 ...

  7. vs 的git插件

    在vs2013上Tfs提供的git管理完全无法理解他的管理方式,还是 Git Source Control Provider 好用用. 下载地址: [http://gitscc.codeplex.co ...

  8. [移动] Xamarin install

    It was not possible to complete an automatic installation. This might be due to a problem with your ...

  9. BeanWrapper

    BeanWrapper是对Bean的包装,其接口中所定义的功能很简单包括设置获取被包装的对象,获取被包装bean的属性描述器,由于BeanWrapper接口是PropertyAccessor的子接口, ...

  10. windows下的zookeeper安装

    先在官网下载安装包(https://www.apache.org/dyn/closer.cgi/zookeeper/),单机安装非常简单,只要获取到 Zookeeper 的压缩包并解压到某个目录如:C ...