当前位置: 首页 > news >正文

Mysql主从搭建 基于DOCKER

创建目录

#主节点目录
mkdir -p /home/data/master/mysql/#从节点目录
mkdir -p /home/data/slave/mysql/

创建配置文件

# 主节点配置
touch /home/data/master/mysql/my.cnf# 从节点配置
touch /home/data/slave/mysql/my.cnf

编辑配置文件

主节点配置文件

vim /home/data/master/mysql/my.cnf
[mysqld]
# 开启 binlog
log-bin=mysql-bin
binlog_format=row
#server_id不要重复
server-id=1

从节点配置文件

vim /home/data/slave/mysql/my.cnf
[mysqld]
# 开启 binlog
log-bin=mysql-bin
binlog_format=row
#server_id不要重复
server-id=2

部署节点

部署主节点

docker run \-p 3307:3306 \-e MYSQL_ROOT_PASSWORD=123456 \-v /home/data/master/mysql/conf:/etc/mysql/conf.d \-v /home/data/master/mysql/data:/var/lib/mysql:rw \-v /home/data/master/mysql/my.cnf:/etc/mysql/my.cnf \--name mysql_master \--restart=always \-d mysql:8.0

部署从节点

docker run \-p 3308:3306 \-e MYSQL_ROOT_PASSWORD=123456 \-v /home/data/slave/mysql/conf:/etc/mysql/conf.d \-v /home/data/slave/mysql/data:/var/lib/mysql:rw \-v /home/data/slave/mysql/my.cnf:/etc/mysql/my.cnf \--name mysql_slave \--restart=always \-d mysql:8.0

配置权限

主节点执行

-- 创建slave用户
CREATE USER 'demo_slave'@'%';
-- 设置密码
ALTER USER 'demo_slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456789';
-- 授予复制权限
GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'demo_slave'@'%';
-- 刷新权限
FLUSH PRIVILEGES;

主节点执行命令

SHOW MASTER STATUS;

该命令会返回以下信息:

名称说明
File当前正在写入的二进制日志文件名
Position当前正在写入的二进制日志文件的位置
Binlog_Do_DB指定需要写入二进制日志的数据库名
Binlog_Ignore_DB指定不需要写入二进制日志的数据库名

在这里插入图片描述

配置从库读取主节点配置

change master to master_host='主节点ip', master_user='demo_slave', master_password='123456789', master_port=3307, master_log_file='mysql-bin.000003', master_log_pos=2023, master_connect_retry=30;

参数说明

参数说明
master_portMaster的端口号,指的是容器的端口号
master_user用于数据同步的用户
master_password用于同步的用户的密码
master_log_file指定Slave从哪个日志文件开始复制数据,即上文中提到的File字段的值
master_log_pos从哪个Position开始读,即上文中提到的Position字段的值
master_connect_retry如果连接失败,重试的时间间隔,单位是秒,默认是60秒

设置从数据库开启主从服务

start slave;

查询下当前从服务器的状态

show slave status;

在这里插入图片描述

  • Slave_IO_RunningSlave_SQL_Running 都是Yes 就成功了,可以进行测试一下
http://www.lryc.cn/news/111139.html

相关文章:

  • Leaflet入门,地图平移跳转到指定位置和飞行到指定位置效果
  • iMX6ULL驱动开发 | 让imx6ull开发板支持usb接口FC游戏手柄
  • Java 实现 SCP 携带密码拷贝文件
  • Flink CEP(三)pattern动态更新
  • 抽象工厂模式(C++)
  • 程序员面试金典17.*
  • 【瑞吉外卖项目复写】基本部分复写笔记
  • 用html+javascript打造公文一键排版系统15:一键删除所有空格
  • 苍穹外卖day12(完结撒花)——工作台+Spring_Apche_POI+导出运营数据Excel报表
  • SQL与NoSQL概念(详细介绍!!)
  • node debian 镜像 new Date 获取时间少 8 小时问题
  • 【N32L40X】学习笔记13-软件IIC读写EEPROM AT24C02
  • JVM 调优
  • DP-GAN剩余代码
  • 在word的文本框内使用Endnote引用文献,如何保证引文编号按照上下文排序
  • SpringBoot项目上传至服务器
  • C++中实现多线程的三种方式
  • 程序员副业指南:怎样实现年入10w+的目标?
  • excel 计算 分位值
  • mongodb-windows-x86_64-4.4.23-signed.msi
  • 一个SpringBoot 项目能处理多少请求?
  • Shell编程基础(十)读取多行文本到数组 写入多行文本到文件
  • MyBatis学习笔记2
  • spring总结
  • 记录--说一说css的font-size: 0
  • Matlab实现支持向量机算法(附上多个完整仿真源码)
  • AIGC大模型ChatGLM2-6B:国产版chatgpt本地部署及体验
  • [国产MCU]-BL602开发实例-开发环境搭建
  • 春秋云镜 CVE-2020-26048
  • 使用Golang实现一套流程可配置,适用于广告、推荐系统的业务性框架——简单应用