MySQL主从复制(一主两从)架构搭建(阿里云服务器)

建立主机master

1.建立数据库master

复制代码
docker run --name master --restart always -p 3308:3306 -v /root/docker/volumes/etc/master:/etc/mysql -v /root/docker/volumes/var/lib/master:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=riCXT8zM -d mysql:latest

2.复制master的配置文件到docker

复制代码
docker cp master:/etc/my.cnf /root/docker/volumes/etc/master/my.cnf

3.卸载并安装master

复制代码
docker stop master
docker rm master
docker run --name master -p 3308:3306 -v /root/docker/volumes/etc/master/my.cnf:/etc/my.cnf -v /root/docker/volumes/etc/master/my.cnf.d:/etc/mysql/my.cnf.d -v /root/docker/volumes/etc/master/conf.d:/etc/mysql/conf.d -v /root/docker/volumes/var/lib/master:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=riCXT8zM -d mysql:latest

建立从机slave

1.建立数据库slave01

复制代码
docker run --name slave01 --restart always -p 3309:3306 -v /root/docker/volumes/etc/slave01:/etc/mysql -v /root/docker/volumes/var/lib/slave01:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=riDYQ8zM -d mysql:latest

2.复制slave01的配置文件到容器

复制代码
docker cp slave01:/etc/my.cnf /root/docker/volumes/etc/slave01/my.cnf

3.卸载并安装slave01

复制代码
docker stop slave01
docker rm slave01
docker run --name slave01 -p 3309:3306 -v /root/docker/volumes/etc/slave01/my.cnf:/etc/my.cnf -v /root/docker/volumes/etc/slave01/my.cnf.d:/etc/mysql/my.cnf.d -v /root/docker/volumes/etc/slave01/conf.d:/etc/mysql/conf.d -v /root/docker/volumes/var/lib/slave01:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=riDYQ8zM -d mysql:latest

建立从机slave02与slave01类似!!!

1.建立数据库slave02

复制代码
docker run --name slave02 --restart always -p 3310:3306 -v /root/docker/volumes/etc/slave02:/etc/mysql -v /root/docker/volumes/var/lib/slave02:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=riEZG8zM -d mysql:latest

2.复制slave02的配置文件到容器

复制代码
docker cp slave02:/etc/my.cnf /root/docker/volumes/etc/slave02/my.cnf

3.卸载并安装slave01

复制代码
docekr stop slave02  #停止容器slave02
docker rm slave02  #移除容器slave02
docker run --name slave02 -p 3310:3306 -v /root/docker/volumes/etc/slave02/my.cnf:/etc/my.cnf -v /root/docker/volumes/etc/slave02/my.cnf.d:/etc/mysql/my.cnf.d -v /root/docker/volumes/etc/slave02/conf.d:/etc/mysql/conf.d -v /root/docker/volumes/var/lib/slave02:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=riEZG8zM -d mysql:latest

主从联系步骤

1.在三个数据库分别执行

复制代码
show variables like 'server_id';

可以看到都是以下一样的结果:

2.配置my.cnf配置文件

主机master配置日志

复制代码
# start~
datadir=/var/lib/mysql
# 是否开启mysql日志  0:关闭(默认值) 1:开启
general-log=1
# mysql 日志的存放位置
general_log_file="/var/lib/mysql/logs/master.log"

slow-query-log=1

slow_query_log_file="/var/lib/mysql/logs/master-slow.log"

long_query_time=10

# Error Logging.
log-error="/var/lib/mysql/logs/master.err"
# end~
  • 方法一
    • 在slave01和slave02上配置文件my.cnf以下代码

slave01:

复制代码
server_id=2

slave02:

复制代码
server_id=3

执行完后执行在服务器终端执行以下代码:

复制代码
docker restart slave01
docker restart slave02

mysql命令行

复制代码
#重新查一下server_id
show variables like 'server_id';
  • 方法二:执行命令
    • 在slave01与slave02上配置文件my.cnf以下代码

slave01:

复制代码
docker exec -it slave01 /bin/bash
cat /etc/my.cnf
sed -i '$a server_id=2' /etc/my.cnf
docker restart slave01
mysql> show variables like 'server_id';

slave02:

复制代码
docker exec -it slave01 /bin/bash
cat /etc/my.cnf
sed -i '$a server_id=2' /etc/my.cnf
docker restart slave01
mysql> show variables like 'server_id'; 

mysql命令行:

复制代码
#重新查一下server_id
show variables like 'server_id';

如果server_id分别为1,2,3,则成功!!!

3.先查看主机master数据库的日志

复制代码
mysql> show master status;

4.在从机slave01,slave02分别在sql命令行执行以下代码

复制代码
change master to
master_port=3308,(主机端口号)
master_user='root',
master_password='riCXT8zM',(主机密码)
master_host='172.20.16.116',(填自己ip)
master_log_file='binlog.000003',(按照日志填)
master_log_pos=157;(按照日志填)

5.开启主从服务(slave01,slave02的终端执行)

复制代码
mysql> start slave;

查看是否配置成功

复制代码
mysql> show slave status \G;

由于在navicat上执行可视化不怎么好看,难以看出什么东西,我们从服务器进入MySQL进行输入

拓展补充:

执行show slave status \G;显示以下:

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

则成功
MySQL主从复制(一主两从)读写分离架构 安全规范 重启步骤:

Linux> docker stop slave01;

Linux> docker stop salve02;

Linux> docker stop master;

Linux> docker start master;

Linux> docker start slave01;

Linux> docker start slave02;
进入容器后台与数据终端的基本命令:

Linux> docker exec -it slave01 bash

Linux> docker exec -it slave01 /bin/bash

mysql> mysql -uroot(用户) -priDYQ8zM(密码)

Linux> docker exec -it slave02 /bin/bash

mysql> mysql -uroot(用户) -priEZG8zM(密码)

相关推荐
sun03224 分钟前
【架构基础】Spring中的PropertySourcesPlaceholderConfigurer介绍 (并非新知识,比较古老的一种使用方式)
java·spring·架构
czlczl200209258 分钟前
增删改查时如何提高Mysql与Redis的一致性
数据库·redis·mysql
打工的小王9 分钟前
MySql(二)索引
数据库·mysql
数据知道9 分钟前
PostgreSQL 性能优化:如何提高数据库的并发能力?
数据库·postgresql·性能优化
wengqidaifeng10 分钟前
数据结构(三)栈和队列(上)栈:计算机世界的“叠叠乐”
c语言·数据结构·数据库·链表
数据知道11 分钟前
PostgreSQL性能优化:内存配置优化(shared_buffers与work_mem的黄金比例)
数据库·postgresql·性能优化
静听山水14 分钟前
Redis核心数据结构
数据结构·数据库·redis
静听松涛13317 分钟前
大语言模型长上下文技术突破:如何处理超长文本的注意力机制与架构图解
人工智能·语言模型·架构
YaHuiLiang22 分钟前
小微互联网公司与互联网创业公司-AI编程需要理性看待
架构
流㶡23 分钟前
MySQL 常用操作指南(Shell 环境)
数据库