博客
关于我
Docker搭建分布式MySQL主从服务
阅读量:399 次
发布时间:2019-03-05

本文共 2233 字,大约阅读时间需要 7 分钟。

在Docker中配置MySQL主从复制环境

1. 安装并配置Docker环境

首先,我们需要创建一个docker-compose.yml文件来配置MySQL主从服务器的环境。以下是具体步骤:

创建配置文件

mkdir mysql_servercd mysql_serversudo vim docker-compose.yml

配置文件说明

version: "3"services:  mysql_1:    image: mysql:5.7    ports:      - "3306:3306"    volumes:      - "/root/mysql_server/node1/data:/var/lib/mysql"      - "/root/mysql_server/node1/conf.d:/etc/mysql/conf.d"    environment:      - MYSQL_ROOT_PASSWORD=123456    restart: always  mysql_2:    image: mysql:5.7    ports:      - "3307:3306"    volumes:      - "/root/mysql_server/node2/data:/var/lib/mysql"      - "/root/mysql_server/node2/conf.d:/etc/mysql/conf.d"    environment:      - MYSQL_ROOT_PASSWORD=123456    restart: always  mysql_3:    image: mysql:5.7    ports:      - "3308:3306"    volumes:      - "/root/mysql_server/node3/data:/var/lib/mysql"      - "/root/mysql_server/node3/conf.d:/etc/mysql/conf.d"    environment:      - MYSQL_ROOT_PASSWORD=123456    restart: always

启动服务

sudo docker-compose up

查看端口状态

netstat -lntp

2. 配置MySQL主从复制

安装必要工具

由于Docker容器中没有安装vim,我们需要先安装vim工具:

docker exec -it mysql_server_mysql_1 apt-get update && sudo apt-get install vim

配置主从服务器

修改MySQL配置文件

进入各个节点并修改配置文件:

docker exec -it mysql_server_mysql_1 vim /etc/mysql/mysql.conf.d/mysqld.cnf

mysqld.cnf中添加以下内容:

[mysqld]server-id=100log-bin=mysql-bin

同样地,对mysql_2mysql_3节点进行相同配置:

docker exec -it mysql_server_mysql_2 vim /etc/mysql/mysql.conf.d/mysqld.cnf
docker exec -it mysql_server_mysql_3 vim /etc/mysql/mysql.conf.d/mysqld.cnf

mysqld.cnf中添加:

[mysqld]server-id=101log-bin=mysql-slave-bin
[mysqld]server-id=102log-bin=mysql-slave-bin

启动并验证主库

进入主库节点(如mysql_1)并启动服务:

sudo docker exec -it mysql_server_mysql_1 systemctl start mysql

查看主库状态:

sudo docker exec -it mysql_server_mysql_1 show master status

获取主库IP地址

查看主库的Docker内网IP:

sudo docker inspect mysql_server_mysql_1

从库同步数据

进入从库节点(如mysql_2)并执行以下命令:

CHANGE MASTER TO   MASTER_HOST='172.18.0.4',  MASTER_USER='root',  MASTER_PASSWORD='123456',  MASTER_LOG_FILE='mysql-bin.000003',  MASTER_LOG_POS=154;

查看同步状态

检查从库的同步状态:

show slave status\G

处理同步问题

如果出现同步问题,可以执行以下命令:

stop slave;SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1; START SLAVE;start slave;

注意事项

  • 主库的数据新增、修改、删除会自动同步到从库。
  • 如果出现同步延迟,可以重启slave服务。

通过以上步骤,我们可以成功配置一个基于Docker的MySQL主从复制环境。

转载地址:http://dsqzz.baihongyu.com/

你可能感兴趣的文章
opencv之模糊处理
查看>>
Opencv介绍及opencv3.0在 vs2010上的配置
查看>>
OpenCV使用霍夫变换检测图像中的形状
查看>>
opencv保存图片路径包含中文乱码解决方案
查看>>
OpenCV保证输入图像为三通道
查看>>
OpenCV入门教程(非常详细)从零基础入门到精通,看完这一篇就够了
查看>>
opencv图像分割2-GMM
查看>>
opencv图像分割3-分水岭方法
查看>>
opencv图像切割1-KMeans方法
查看>>
OpenCV图像处理篇之阈值操作函数
查看>>
opencv图像特征融合-seamlessClone
查看>>
OpenCV图像的深浅拷贝
查看>>
OpenCV在Google Colboratory中不起作用
查看>>
OpenCV学习(13) 细化算法(1)(转)
查看>>
OpenCV学习笔记(27)KAZE 算法原理与源码分析(一)非线性扩散滤波
查看>>
OpenCV学堂 | CV开发者必须懂的9种距离度量方法,内含欧氏距离、切比雪夫距离等(建议收藏)
查看>>
OpenCV学堂 | OpenCV中支持的人脸检测方法整理与汇总
查看>>
OpenCV学堂 | OpenCV案例 | 基于轮廓分析对象提取
查看>>
OpenCV学堂 | YOLOv8与YOLO11自定义数据集迁移学习效果对比
查看>>
OpenCV学堂 | YOLOv8官方团队宣布YOLOv11 发布了
查看>>