MySQL主从配置

Posted You295

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL主从配置相关的知识,希望对你有一定的参考价值。

一:简介

主从同步可以使数据从一个数据库服务器复制到其他的服务器上,在复制的时候,一个数据库服务器当做主服务器(master),其余的服务器当做从服务器(slave)。复制是异步进行的,故服务器不需要一直连接着主服务器,并且从服务器也是可以通过拨号的方式断断续续的连接主服务器。通过配置文件,可以指定复制所有的数据库,或者某个数据库,甚至是某个数据库上的某个表。

二:优点

1)如果主库出现问题的时候,可以快速的切换到从库来提供服务。
2)可以再从库上执行查询操作,在主库中更新,以此来减轻主库的压力。
3)实现读写分离,在从库中执行备份,避免在备份期间影响主库的服务。

三:流程(docker下mysql的主从配置)

1.docker中安装mysql

1.1.从仓库中查询mysql

[root@localhost ~]# docker search mysql


1.2。 下载mysql镜像

[root@localhost ~]# docker pull docker.io/mysql


1.3. 查询镜像是否下载成功

[root@localhost ~]# docker image ls


1.4. 运行docker 容器(container, 主服务器(master))

docker run -itd --name=mysql_master -p 3310:3306 -e MYSQL_ROOT_PASSWORD=123 docker.io/mysql


1.5. 查询mysql进程是否启动

[root@localhost ~]# docker ps

1.6.和上面同样的方法下载一个从容器

1.7。运行从容器

[root@localhost ~]# docker run -itd --name=mysql_slave -p 3311:3306 -e MYSQL_ROOT_PASSWORD=123 docker.io/mysql

1.8查看启动的container

两个数据库都启动即可。

2. 配置主(master)服务器

2.1 进入master服务器容器内

[root@localhost ~]# docker exec -it mysql_master /bin/bash

2.2 进入/etc/mysql文件夹

root@4abf554ea1e4:/# cd etc/ 
root@4abf554ea1e4:/etc# cd mysql 
root@4abf554ea1e4:/etc/mysql# 
root@4abf554ea1e4:/etc/mysql# ls 
conf.d my.cnf my.cnf.fallback

2.3 使用vi/vim编辑my.cnf文件

显示上面的信息,证明没有安装vim,即需要安装vim
2.3.1。执行 apt-get update

root@4abf554ea1e4:/etc/mysql# apt-get update

2.3.2。执行apt-get install vim 安装vim

root@4abf554ea1e4:/etc/mysql# apt-get install vim

2.3.3.使用vi编辑 my.cnf

root@4abf554ea1e4:/etc/mysql# vi my.cnf


2.3.4.在my.cnf添加代码(使用“i” 键进入编辑模式

保存修改

按回车键继续

重新启动容器让配置生效

2.4.创建专用账户(slave)进行主从同步
2.4.1.使用root账户登入mysql

[root@localhost ~]# docker exec -it mysql_master /bin/bash
 root@4abf554ea1e4:/# mysql -u root -p 
 Enter password:

2.4.2.创建专用同步账户(slave)

3.配置从(slave)容器

3.1。 进入slave服务器容器内

3.2.进入/etc/mysql文件夹

3.3。使用vi/vim编辑my.cnf文件
没有安装同上方在主容器中安装vim方法一样
安装好后进入:

4.主从复制

4.1。查看master状态
4.4.1。进入master mysql 容器

[root@localhost ~]# docker exec -it mysql_master /bin/bash 
[root@4abf554ea1e4:/# mysql -u slave -p

4.4.2.显示主服务器状态

mysql> show master status;


4.2.在slave中执行命令
4.2.1.查询master容器的独立IP

[root@localhost ~]# docker inspect --format='.NetworkSettings.IPAddress' mysql_master 
## mysql_master--master容器的名称


4.2.2.进入slave容器中

[root@localhost ~]# docker exec -it mysql_slave /bin/bash


4.2.3.执行SQL语句

mysql> change master to 
master_host='172.17.0.2',  
master_user='slave', 
master_password='123', 
MASTER_LOG_FILE='mysql-bin.000001', 
MASTER_LOG_POS=1327; 

Query OK, 0 rows affected, 8 warnings (0.03 sec)


4.2.4.开启主从复制过程

mysql> start slave;
 Query OK, 0 rows affected, 1 warning (0.00 sec)



到此就配置结束

5. 问题及解决方案

第一种错误情况

error connecting to master ‘slave@172.17.0.2:3306’ - retry-time: 60 retries: 2 message:
Authentication plugin ‘caching_sha2_password’ reported error: Authentication requires
secure connection.
解决办法:在master服务器修改用户密码信息

ALTER USER ‘slave’@’%’ IDENTIFIED WITH mysql_native_password BY ‘123;
FLUSH PRIVILEGES;

解锁表

unlock tables

第二种错误情况

Slave failed to initialize relay log info structure from the repository, Error_code: 1872
解决方案:
stop slave; //关闭slave
reset slave;//重置slave
重新运行change master to :

mysql> change master to 
master_host='172.17.0.2', 
master_user='slave', 
master_password='123', 
MASTER_LOG_FILE='mysql-bin.000001', 
MASTER_LOG_POS=1327; 

Query OK, 0 rows affected, 8 warnings (0.03 sec)

start slave;

以上是关于MySQL主从配置的主要内容,如果未能解决你的问题,请参考以下文章

mysql主从配置

Mysql主从配置

第五章:MySQL主从复制

MySQL传统主从配置

Redis主从复制的配置过程

安全最重要!MySQL配置主从复制,主主复制