docker实现mysql主从复制(巨详细!!!)

news2025/1/12 0:01:14

docker实现mysql主从复制(巨详细!!!)

    • 新建主机服务容器实例3307
    • 进入/mydata/mysql-master/conf目录下新建my.cnf
    • 修改完配置后重启master实例
    • 进入mysql-master容器
    • master容器实例内创建数据同步用户
    • 新建 服务器容器实例3308
    • 进入/mydata/mysql-slave/conf目录新建my.cnf
    • 修改完配置后重启slave实例
    • 在主数据库中查看同步状态
    • 进入mysql-slave容器
    • 在从数据库中配置主从
    • 在从数据库中查看主从同步状态
    • 在从数据库中开启主从同步
    • 查看从数据库状态发现已经同步
    • 主从复制测试

新建主机服务容器实例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

这段代码是用于在 Docker 中启动一个名为 mysql-master 的 MySQL 5.7 数据库容器的命令,并将其映射到主机的 3307 端口。具体参数含义如下:

  • docker run: Docker 命令,用于创建并启动 Docker 容器。
  • -p 3307:3306: 将 Docker 容器的 3306 端口映射到主机的 3307 端口。
  • --name mysql-master: 为 Docker 容器指定一个名称。
  • -v /mydata/mysql-master/log:/var/log/mysql: 将主机上的目录 /mydata/mysql-master/log 挂载到 Docker 容器的 /var/log/mysql 目录,用于容器中数据库日志文件的存放。
  • -v /mydata/mysql-master/data:/var/lib/mysql: 将主机上的目录 /mydata/mysql-master/data 挂载到 Docker 容器的 /var/lib/mysql 目录,用于容器中数据库文件的存放。
  • -v /mydata/mysql-master/conf:/etc/mysql: 将主机上的目录 /mydata/mysql-master/conf 挂载到 Docker 容器的 /etc/mysql 目录,用于容器中 MySQL 配置文件的存放。
  • `-e MYSQL_ROOT_PASSWORD=root: 设置容器中 MySQL 数据库的 root 用户密码为 root。
  • -d mysql:5.7: 使用 Docker Hub 中的 mysql:5.7 镜像创建容器,并以后台方式运行。

综合上述参数,该命令会创建一个名为 mysql-master 的 MySQL 5.7 数据库容器,并将其映射到主机的 3307 端口,同时将容器中数据库的日志文件、数据文件和配置文件挂载到主机上指定的目录。容器中的 MySQL 数据库的 root 用户密码将被设置为 ROOT。该命令在后台运行,并返回容器的 ID。

进入/mydata/mysql-master/conf目录下新建my.cnf

cd /mydata/mysql-master/conf
vim my.cnf

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

修改完配置后重启master实例

docker restart mysql_master

进入mysql-master容器

docker exec -it mysql_master /bin/bash
mysql-uroot-proot
  • mysql:启动 MySQL 客户端程序。
  • -uroot:指定连接的用户名为 root。
  • -proot:指定连接的密码为 root。

master容器实例内创建数据同步用户

CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.*TO 'slave'@'%';

这是两个 MySQL 数据库命令用于创建一个名为 ‘slave’ 的用户,并授予该用户复制从库和复制客户端的权限。具体命令含义如下:

  1. CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
    • CREATE USER: 创建一个新用户。
    • 'slave'@'%': 用户名和允许连接的主机。在这里,用户名为 ‘slave’,‘%’ 表示允许从任何主机连接。
    • IDENTIFIED BY '123456': 设置用户的密码为 ‘123456’。
  2. GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
    • GRANT: 授予权限给指定用户。
    • REPLICATION SLAVE, REPLICATION CLIENT: 授予复制从库和复制客户端的权限。
    • *.*: 要授权的数据库和表。在这里,*.* 表示所有数据库和表。
    • TO 'slave'@'%': 授予权限的用户和允许连接的主机。

综合上述命令,第一个命令创建了一个名为 ‘slave’ 的用户,并设置其密码为 ‘123456’,允许从任何主机连接。第二个命令给该用户授予了复制从库和复制客户端的权限,并对所有数据库和表进行授权。这样,用户 ‘slave’ 就可以作为一个复制从库连接到 MySQL 主服务器,并进行数据复制操作。

新建 服务器容器实例3308

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

cd /mydata/mysql-slave/conf
vim 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,row)
binlog_format=mixed
##二进制日志过期清理时间。默认值为0,表示不自动清理
expire_logs_days=7
##跳过主从复制中遇到的所有错误或制动类型的错误,避免slave端复制中断
##如:1062错误是指一下主键重复,1032错误是因为主从数据不一致
slave_skip_errors=1062
##relay_log配置中继日志
relay_log=mall-mysql-relay-bin
##log_slave_updates表示slave将表示复制事件写进自己的二进制日志
log_slave_updates=1
##slave设置为只读(具有super权限的用户除外)
read_only-1

修改完配置后重启slave实例

docker restart mysql-slave

在主数据库中查看同步状态

show master status;

进入mysql-slave容器

docker exec -it mysql-slave /bin/bsh
mysql -uroot -proot

在从数据库中配置主从

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=617,master_connect_retry=30;
  • CHANGE MASTER TO`:指定要修改主从复制配置。
  • MASTER_HOST='宿主机ip':设置主服务器的 IP 地址(或主机名)。
  • MASTER_USER='slave':设置主服务器的用户名。
  • MASTER_PASSWORD='123456':设置主服务器的密码。
  • MASTER_PORT=3307:设置主服务器的端口号。
  • MASTER_LOG_FILE='mall-mysql-bin.000001':设置主服务器的二进制日志文件名。
  • MASTER_LOG_POS=617:设置主服务器的二进制日志位置。
  • MASTER_CONNECT_RETRY=30:设置从服务器重试连接主服务器的间隔时间(单位:秒)。

通过执行这个命令,可以将从服务器配置为连接到指定的主服务器,并使用指定的凭据进行认证和复制操作。请确保替换 '宿主机ip''slave''123456''mall-mysql-bin.000001'617 为正确的主服务器信息。

在从数据库中查看主从同步状态

show slave status \G;

在这里插入图片描述

在从数据库中开启主从同步

start slave;

查看从数据库状态发现已经同步

在这里插入图片描述

主从复制测试

主机新建库-使用库-新建表-插入数据,ok
在这里插入图片描述

从机使用库-查看记录,ok

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1037359.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【论文阅读】内存数据库并发控制算法的实验研究

内存数据库并发控制算法的实验研究 原文链接jos.org.cn/jos/article/pdf/6454 摘要 并发控制算法的基本思想归纳为"先定序后检验”,基于该思想对现有各类并发控制算法进行 了重新描述和分类总结,于在开源内存型分布式事务测试床 3TS 上的实际对比实…

Tune-A-Video论文阅读

论文链接:Tune-A-Video: One-Shot Tuning of Image Diffusion Models for Text-to-Video Generation 文章目录 摘要引言相关工作文生图扩散模型文本到视频生成模型文本驱动的视频编辑从单个视频生成 方法前提DDPMsLDMs 网络膨胀微调和推理模型微调基于DDIM inversio…

动手学深度学习(pytorch版)第二章-2.3线性代数Note-linear-algebra

类型 标量:仅包含一个数值被称为标量 向量:向量可以被视为标量值组成的列表 矩阵:正如向量将标量从零阶推广到一阶,矩阵将向量从一阶推广到二阶。 A torch.arange(20).reshape(5, 4) A.T //转置 张量:是描述具有…

[36c3 2019]includer

[36c3 2019]includer 题目描述:Just sitting here and waiting for PHP 8.0 (lolphp). 首先来了解一下临时文件包含之PHP - compress.zlib:// 在 php-src 里可以找到和 compress.zlib:// 有关的代码 | code 注意到 STREAM_WILL_CAST,涉及到 cast 经常…

企业微信-通用开发参数回调设置

公司业务需要开发企业微信,注册三方服务商审核通过后, 开始配置开发信息。本篇中记录在调试url验证中遇到错误及解决方式。 目录 准备工作 下载php加解密库 下载文件说明 设置白名单 设置路径 参数说明 设置ip 回调处理 回调类型: …

【C++】布隆过滤器简单操纵模拟以及常见题目

🌏博客主页: 主页 🔖系列专栏: C ❤️感谢大家点赞👍收藏⭐评论✍️ 😍期待与大家一起进步! 文章目录 前言一、求下标仿函数的建议二、布隆过滤器代码面试题1.近似算法:2.精确算…

Leetcode 409. 最长回文串

文章目录 题目代码&#xff08;9.24 首刷自解&#xff09; 题目 Leetcode 409. 最长回文串 代码&#xff08;9.24 首刷自解&#xff09; class Solution { public:int longestPalindrome(string s) {unordered_map<char, int> mp;for(char c : s) mp[c];int res 0;int…

【算法思想-排序】排序数组-力扣 912 题

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…

nexus 私服 拉不了 jar 包,报 Not authorized

如果你排查了所有情况,并且确定账号密码都没问题,路径也正确,并且setting.xml都配置正确了 可以看下是不是这个原因

5、SpringBoot_热部署

六、热部署 1.热部署概述 概述&#xff1a;程序更改后&#xff0c;不需要重新启动服务器也能够实现动态更新 springboot 项目如何实现热部署&#xff1f; tomcat 已经内置到项目容器中了希望tomcat监听外部程序变化通过新建一个程序来监控你代码的变化 2.依赖导入 依赖 <…

2023蓝帽杯半决赛misc题目复现

后续会逐渐完善&#xff1a; misc--排排坐吃果果 我真是无大语了&#xff0c;对于我的死脑筋&#xff0c;文件一打开是一片白色&#xff0c;但是点开单元格会看到里面有数字&#xff0c;我想到了修改单元格的格式&#xff0c;就是没想到转换字体的颜色&#xff0c;对此我表示…

构建基于neo4j知识图谱、elasticsearch全文检索的数字知识库

前言&#xff1a; 在数字化时代&#xff0c;知识库的建设正逐渐成为企业、学术机构和个人的重要资产。本文将介绍如何使用neo4j和elasticsearch这两种强大的数据库技术来构建知识库&#xff0c;并对其进行比较和探讨。 技术栈&#xff1a; springbootvueneo4jelasticsearch…

map的一些测试-string键的查找

主要区别在于声明map的时候多了一个less<> #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> #include <map> #include <chrono> using namespace std; class spender { public:spender(string strfun) :strfun(strfun…

LeetCode算法二叉树—相同的树

目录 100. 相同的树 - 力扣&#xff08;LeetCode&#xff09; 代码&#xff1a; 运行结果&#xff1a; 给你两棵二叉树的根节点 p 和 q &#xff0c;编写一个函数来检验这两棵树是否相同。 如果两个树在结构上相同&#xff0c;并且节点具有相同的值&#xff0c;则认为它们是…

FPGA的DQPSK调制解调Verilog

名称&#xff1a;DQPSK调制解调 软件&#xff1a;Quartus 语言&#xff1a;Verilog 要求&#xff1a; 使用Verilog语言进行DQPSK调制和解调&#xff0c;并进行仿真 代码下载&#xff1a;DQPSK调制解调verilog&#xff0c;quartus_Verilog/VHDL资源下载 代码网&#xff1a;h…

哈希表9.24

13.罗马数字转整数 13. 罗马数字转整数 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/roman-to-integer/?envTypelist&envIdsxrVTWKy目的是将一串罗马数字字符串转为整数 使用哈希存储罗马字母对应的数字可以很方便我们遍历字符串时快速找到对应…

代码随想录Day02 数组基础2 leetcode T977有序数组的平方, T209 长度最小的子数组,T59 螺旋矩阵II

本文思路和详细解答来源于: 代码随想录 视频讲解见: 双指针法经典题目 | LeetCode&#xff1a;977.有序数组的平方_哔哩哔哩_bilibili Leetcode T977 有序数组的平方 题目链接: 977. 有序数组的平方 - 力扣&#xff08;LeetCode&#xff09; 思路1: 暴力求解 这里先解释一下非…

如何满足计算机化系统验证(CSV):制药企业的指南

随着科技的不断发展&#xff0c;制药企业在其日常运营中越来越多地依赖计算机化系统。这些系统涵盖了从研发到生产再到分销的各个领域&#xff0c;它们对于确保药品质量、跟踪生产流程以及维护患者安全至关重要。为了满足监管机构的法规要求&#xff0c;如美国FDA、欧盟Annex 1…

别再费劲配音了!小说推文视频一键生成,并带全自动配音

下面教你轻松一键制作出精彩的小说推文视频。 1. 输入文案生成小说推文视频 小说推文视频可以根据你输入的文案自动生成精美的视频内容&#xff0c;无需手动操作。只需提供文案&#xff0c;小说推文视频就能为你制作出令人惊艳的视频作品。 2. 自动小说推文配音 不用再费心去…

力扣:108. 将有序数组转换为二叉搜索树(Python3)

题目&#xff1a; 给你一个整数数组 nums &#xff0c;其中元素已经按 升序 排列&#xff0c;请你将其转换为一棵 高度平衡 二叉搜索树。 高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。 来源&#xff1a;力扣&#xff08;LeetCode&…