Mysql/MariaDB配置主从复制备份

数据库安装配置好后,如果你的web项目对数据要求比较严谨,那就需要对数据进行备份。一般项目我们采用主从双机热备份机制来保证数据可靠性,当然也可以采用主主互备高可用机制。本文先介绍Mysql/MariaDB主从双机热备份的配置。

Mysql/MariaDB配置主从复制备份

准备

1、主数据库使用CentOS7.2操作系统,MariaDB版本是10.2.12,IP是192.168.11.34。

2、从数据库也使用CentOS7.2操作系统,MariaDB版本也是10.2.12,IP是192.168.11.31。

两台机器环境都一样,保证可以互通,如果开启防火墙的一定记得将MariaDB的3306端口允许开放,如果还不会安装MariaDB的同学可以参考本站文章:

配置主数据库Master

1、设置数据库配置文件

在主服务器(192.168.11.34)上打开MariaDB的配置文件:/etc/my.cnf,找到如下配置项,如果没有请自行添加。

server-id = 1
log-bin = mysql-bin

server-id = 1是指数据库的唯一ID号,默认从1开始。

log-bin = mysql-bin启用二进制日志,备份复制其实就是根据日志来的。

2、重启MariaDB数据库

第1步设置好,需要重启数据库,输入命令/etc/init.d/mariadb restart

[root@localhost ~]# /etc/init.d/mariadb restart
Restarting mariadb (via systemctl):                        [  确定  ]

或者直接输入:

systemctl restart mariadb

3、建立账户并授权从数据库访问

进入MariaDB命令行模式下,输入:

grant replication slave on *.* to 'slave'@'%' identified by '123456x';

以上命令在主数据库中创建了一个专门用于数据备份的账号,账号名为slave,密码为123456x,允许从数据库访问。

如果只允许从数据库连接,可以将以上命令中的“%”改成从数据库的IP即可,参照:

配置好账户后,重载权限使之立即生效。

flush privileges;

4、检查主数据库的master状态

在MariaDB的命令行中输入show master status;,会列出当前主数据库用户同步复制的关键参数:

MariaDB [(none)]> show master status;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000004 |     2259 |              |                  |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

我们需要记下File和Position两项的值,他们分别表示bin日志文件名和数据偏移量。

配置从数据库Slave

1、设置从数据库配置文件:/etc/my.cnf。

server-id = 2
log-bin = mysql-bin
replicate-do-db = helloweba

以上选项中,server-id = 2表示从数据库ID,一定不能和主数据库一样。

log-bin = mysql-bin二进制日志。

replicate-do-db = helloweba设置了允许同步复制的数据库为helloweba,如果不设置则可注释掉该行。

2、重启数据库

和主数据库一样,配置好后要重启数据库使配置生效。

[root@localhost ~]# /etc/init.d/mariadb restart
Restarting mariadb (via systemctl):                        [  确定  ]

3、执行复制命令

进入从数据库命令行模式,输入命令:

change master to master_host='192.168.11.34',master_port=3306,master_user='slave',master_password='123456x',master_log_file='mysql-bin.000004',master_log_pos=2259;

master_host是指主数据库服务器的IP(192.168.11.34),master_user是指登录连接主数据库的账号(slave),master_password是指账号对应的密码,master_port是指主数据库的端口号(3306),master_log_file就是主数据库master状态对应的File文件,master_log_pos就是主数据库master状态对应的Position参数。

4、启动slave同步

数据库命令行模式下,输入start slave;命令:

MariaDB [(none)]> start slave;
Query OK, 0 rows affected (0.01 sec)

5、查看slave同步的状态

输入show slave statusG;命令:

MariaDB [(none)]> show slave statusG;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.11.34
                  Master_User: slave
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000004
          Read_Master_Log_Pos: 2259
               Relay_Log_File: mariadb-relay-bin.000004
                Relay_Log_Pos: 555
        Relay_Master_Log_File: mysql-bin.000004
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: helloweba
          Replicate_Ignore_DB: 

查看Slave_IO_RunningSlave_SQL_Running是否都为yes(一定要全部为yes)。

验证

主从库配置好后,为了验证数据是否同步复制了,可以在主数据库中插入一条数据,然后到从数据库中查看是否也插入了一条数据。同样的,对主数据库的修改和删除操作,在从数据库中也自动进行了相应的操作。

本文来自: http://chenxuhou.com/detail/229.html

免责声明:
1.本站所有内容只做学习和交流使用。 版权归原作者所有。
2.保证站内提供的所有可下载源码资源(软件等)都是按“原样”提供,本站未做过任何改动;但本网站不保证本站提供的下载资源的准确性、安全性和完整性;同时本网站也不承担用户因使用这些下载资源对自己和他人造成任何形式的损失或伤害。
3.本站部分内容均收集于网络!如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。请联系站长邮箱:admin#ibian.online(#换成@)处理!

给TA打赏
共{{data.count}}人
人已打赏
数据库

MariaDB与MySQL的主从复制效率对比

2025-2-25 10:08:40

数据库

MySQL建库、建用户并授权

2025-2-25 10:30:17

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索