目录

主从复制简介 

主从复制搭建


主从复制简介 

主从复制,是用来建立一个和主数据库完全一样的数据库环境,称为从数据库;主数
据库一般是准实时业务数据库

主从复制作用

  1. 数据热备。作为后备数据库,主数据库服务器故障后,可切换到从数据库继续工作避免数据丢失
  2. 架构扩展业务量越来越大,I/O访问频率过高,单机无法满足,此时做多库的存储降低磁盘I/O访问频率提高单个机器I/O性能
  3. 读写分离,使数据库能支撑更大的并发。在报表中尤其重要。由于部分报表sql语句非常的慢,导致锁表,影响前台服务。如果前台使用master,报表使用slave,那么报表sql不会造成前台锁,保证了前台速度

主从复制原理 

  1. 数据库有个binlog二进制文件记录了所有sql语句
  2. 我们目标是把主数据库bin-log文件sql语句复制过来。
  3. 让其在从数据relaylog重做(中继)日志文件中再执行一次这些sql语句即可
  4. 下面的主从配置就是围绕这个原理配置
  5. 具体需要三个线程操作

主从复制搭建

 本次搭建一主一从

新建服务器容器实例3307

docker run -p 3307:3306 --name mysql-master 
-v /mydata/mysql-master/log:/var/log/mysql 
-v /mydata/mysql-master/data:/var/lib/mysql 
-v /mydata/mysql-master/conf:/etc/mysql 
-e MYSQL_ROOT_PASSWORD=root 
-d mysql:5.7

 查看mysql容器

[root@localhost ~]# docker ps
CONTAINER ID   IMAGE         COMMAND                   CREATED         STATUS         PORTS                                                  NAMES
eac439fb07df   mysql:5.7     "docker-entrypoint.s…"   3 minutes ago   Up 3 minutes   33060/tcp, 0.0.0.0:3307->3306/tcp, :::3307->3306/tcp   mysql-master

进入/mydata/mysqlmaster/conf目录并新建my.cnf 

[root@localhost ~]# cd /mydata/mysql-master/conf
[root@localhost conf]# vim my.cnf

编辑my.cnf文件

[mysqld]
## 设置server_id,同一局域网需要唯一
server_id=101
## 指定需要同步数据库名称
binlog-ignore-db=mysql
## 开启二进制日志功能
log-bin=mall-mysql-bin
## 设置二进制日志使用内存大小事务binlog_cache_size=1M
## 设置使用的二进制日志格式mixed,statement,rowbinlog_format=mixed
## 二进制日志过期清理时间默认值为0,表示自动清理expire_logs_days=7
## 跳过主从复制遇到的所有错误指定类型的错误,避免slave复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062

 重启mysql容器

[root@localhost conf]# docker restart mysql-master
mysql-master

进入mysql容器并登录mysql数据库

[root@localhost conf]# docker exec -it mysql-master /bin/bash
root@eac439fb07df:/#  mysql -uroot -proot
mysql> 

 创建数据同步用户

mysql> CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
Query OK, 0 rows affected (0.00 sec)

授予权限

mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
Query OK, 0 rows affected (0.00 sec)
新建从服务器容器实例3308
[root@localhost conf]# docker run -p 3308:3306 --name mysql-slave 
> -v /mydata/mysql-slave/log:/var/log/mysql 
> -v /mydata/mysql-slave/data:/var/lib/mysql 
> -v /mydata/mysql-slave/conf:/etc/mysql 
> -e MYSQL_ROOT_PASSWORD=root 
> -d mysql:5.7
进入
/mydata/mysql-slave/conf目录下新建my.cnf
[root@localhost conf]# cd /mydata/mysql-slave/conf
[root@localhost conf]# vim my.cnf

编辑my.cnf文件

[mysqld]
## 设置server_id,同一局域网需要唯一
server_id=102
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql
## 开启二进制日志功能,以备Slave作为其它数据库实例的Master时使用
log-bin=mall-mysql-slave1-bin
## 设置二进制日志使用内存大小事务binlog_cache_size=1M
## 设置使用的二进制日志格式mixed,statement,rowbinlog_format=mixed
## 二进制日志过期清理时间。默认值为0,表示自动清理。
expire_logs_days=7
## 跳过主从复制遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062

重启slave容器

[root@localhost conf]# docker restart mysql-slave
mysql-slave

查看启动docker容器

[root@localhost conf]# docker ps
CONTAINER ID   IMAGE         COMMAND                   CREATED          STATUS          PORTS                                                  NAMES
f223b1736767   mysql:5.7     "docker-entrypoint.s…"   9 minutes ago    Up 34 seconds   33060/tcp, 0.0.0.0:3308->3306/tcp, :::3308->3306/tcp   mysql-slave
eac439fb07df   mysql:5.7     "docker-entrypoint.s…"   24 minutes ago   Up 15 minutes   33060/tcp, 0.0.0.0:3307->3306/tcp, :::3307->3306/tcp   mysql-master
master主机查看主从同步的状态
记录下Position的值
[root@localhost conf]# docker exec -it mysql-master /bin/bash
root@eac439fb07df:/# mysql -uroot -proot
mysql> show master status;
+-----------------------+----------+--------------+------------------+-------------------+
| File                  | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-----------------------+----------+--------------+------------------+-------------------+
| mall-mysql-bin.000001 |      834 |              | mysql            |                   |
+-----------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

进入
mysql-slave
容器
[root@localhost conf]# docker exec -it mysql-slave /bin/bash
root@f223b1736767:/# mysql -uroot -proot
mysql>
按照如下格式在从数据库配置主从复制
注意master_log_pos参数的值要和主机中的Position参数的值保持一致
change master to master_host='宿主机ip', master_user='slave',
master_password='123456', master_port=3307,
master_log_file='mall-mysql-bin.000001', master_log_pos=Position,
master_connect_retry=30;
mysql> change master to master_host='192.168.117.131', master_user='slave',
    -> master_password='123456', master_port=3307,
    -> master_log_file='mall-mysql-bin.000001', master_log_pos=834,
    -> master_connect_retry=30;
Query OK, 0 rows affected, 2 warnings (0.01 sec)
在从数据库查看主从同步状态
<mysql> show slave status G

在从数据库开启数据同步

mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
查看从数据库状态
mysql> show slave status G
出现两个yes说明主从复制成功

测试主从复制效果

在主机创建数据库,数据表

[root@localhost conf]# docker exec -it mysql-master /bin/bash
root@eac439fb07df:/# mysql -uroot -proot

mysql> create database mysql_db;
Query OK, 1 row affected (0.00 sec)

mysql> use mysql_db;
Database changed

mysql> create table stu(id int,name varchar(20),score double);
Query OK, 0 rows affected (0.01 sec)

mysql> insert into stu(id,name,score) values(1,'eric',99.5);
Query OK, 1 row affected (0.01 sec)

mysql> select * from stu;
+------+------+-------+
| id   | name | score |
+------+------+-------+
|    1 | eric |  99.5 |
+------+------+-------+
1 row in set (0.00 sec)

从机查看数据是否同步 

[root@localhost conf]# docker exec -it mysql-slave /bin/bash
root@f223b1736767:/# mysql -uroot -proot

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| mysql_db           |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

mysql> use mysql_db;

mysql> select * from stu;
+------+------+-------+
| id   | name | score |
+------+------+-------+
|    1 | eric |  99.5 |
+------+------+-------+
1 row in set (0.00 sec)
数据同步成功,至此Docker下mysql数据库主从复制搭建完成

原文地址:https://blog.csdn.net/m0_72832574/article/details/134750733

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_30524.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注