Docker搭建MySQL8.0主从复制(一主一从)

0. 配置说明

宿主机使用的版本为19045的win10专业版,MySQL使用的是8.0+,Docker容器使用Linux。

1. 安装Docker Desktop

修改Docker默认安装路径

安装包自己就提供了修改安装路径的功能,CMD中运行:

“Docker Desktop Installer.exe” install --installation-dir=

--installation-dir=<path>: changes the default installation location (C:\Program Files\Docker\Docker)

2. 在Docker中安装MySQL

可以访问 MySQL 镜像库地址:https://hub.docker.com/_/mysql?tab=tags 查看可用的其他mysql版本,默认为最新版本mysql:latest

2.1 拉取MySQL镜像

$ docker pull mysql:latest

image-20231007130311640

2.2 查看本地镜像

$ docker images

image-20231007130538272

2.3 启动MySQL容器实例

$ docker run --name mysql -p 3309:3306 -e MYSQL_ROOT_PASSWORD=5508769123 -d mysql

参数说明:

  • docker run:告诉Docker启动一个新的容器
  • –name mysql :指定了容器的名称,这里是 “mysql”
  • -p 3309:3306:端口映射设置,将容器内的MySQL数据库端口(默认为3306)映射到主机上的3309端口。这样可以通过主机的3309端口访问MySQL服务器
  • -e MYSQL_ROOT_PASSWORD=5508769123:环境变量的设置,用于配置MySQL容器的根用户(root)的密码。这里,密码被设置为 “5508769123”
  • -d:表示以"后台"(detached)模式运行容器
  • mysql:要运行的Docker镜像的名称

image-20231007133351291

下面给出的输出16821a8792a185997c1b5df334fa4461a157488e90d881902596e7ff3db8c42f为容器的id。

2.4 检查安装

$ docker ps

image-20231007133459706

打开Docker Desktop检查

image-20231007133558413

image-20231007133610652

宿主机登录Docker中的MySQL

image-20231007134012443

3. 主从复制

3.1 设置主库(这里为宿主机器)

  1. 修改主库MySQL数据库的配置文件,这里配置文件位置为:C:\ProgramData\MySQL\MySQL Server 8.0\my.ini

    添加信息为:

    [mysqld]
    log-bin=mysql-bin #必须启用二进制日志
    server-id=100 #必须服务器唯一ID
    

    找到[mysqld]标签然后添加下面两行即可

    image-20231007135215460

  2. 重启MySQL服务

    (管理员权限)

    $ net stop mysql80$ net start mysql80
    

    image-20231007140028457

  3. 在主库创建新用户并赋权

    登录主库然后执行下面两条指令:

    CREATE USER 'mercurows'@'%' IDENTIFIED WITH caching_sha2_password BY '5508769123';
    GRANT REPLICATION SLAVE , REPLICATION CLIENT ON *.* TO 'mercurows'@'%';
    

    **注意:**mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password。我们发现root的加密规则为caching_sha2_password,现在修改为mysql_native_password,

    ALTER USER 'mercurows'@'%' IDENTIFIED WITH 'mysql_native_password' BY '5508769123';
    

    解释:

    • CREATE USER:创建一个新用户。

    • 'mercurows'@'%':新用户的标识符。'mercurows' 是用户名,'%' 表示这个用户可以从任何主机连接到MySQL服务器。如果想限制用户只能从特定主机连接,可以在 '%' 的位置指定相应的主机地址。

    • IDENTIFIED WITH caching_sha2_password BY '5508769123':用户的身份验证方法和密码。在这里用户的身份验证方法被设置为 caching_sha2_password,并且密码被设置为 '5508769123'注意:mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password。

    • REPLICATION SLAVE, REPLICATION CLIENT:表示授予用户 ‘mercurows’ 两种权限:REPLICATION SLAVE(用于复制从其他MySQL服务器)和 REPLICATION CLIENT(用于查询和管理复制状态)。

    • ON *.*:表示授予权限的范围,*.* 表示所有数据库和所有表。

    • TO 'mercurows'@'%':这部分指定了要授予权限的用户和其访问主机。与前一个命令相同,'mercurows'@'%' 表示 ‘mercurows’ 用户可以从任何主机连接。

    检查:

    flush privileges;
    SHOW GRANTS FOR 'mercurows'@'%';
    

    image-20231007141729598

  4. 检查主库状态

    show master status;
    

    image-20231007152113200

并记录FilePosition这两个记录,这里是DESKTOP-UPK0D57-bin.0000381353,注意:在完成设置之前都不能对主库进行操作以免这两个记录发生改变

3.2 设置从库(这里为Docker中的MySQL)

  1. 修改从库MySQL数据库的配置文件,这里文件在/etc/my.cnf

    添加信息为:

    [mysqld]
    server-id=100 #必须服务器唯一ID
    

    找到[mysqld]标签然后添加下面一行然后保存即可

    image-20231007143535953

  2. 重启MySQL服务(我这里直接重启容器了)

  3. 登录从库中的MySQL然后执行下面的语句:

    change master to master_host='192.168.1.172',master_port=3306,master_user='mercurows',master_password='5508769123',master_log_file='DESKTOP-UPK0D57-bin.000038',master_log_pos=1353;start slave;
    

    解释:

    • change master to:告诉MySQL服务器,接下来要更改主从复制的设置
    • master_host='192.168.1.172':指定主数据库的主机名或IP地址。在这里就是我宿主电脑的IP地址
    • master_port=3306:指定主数据库的端口号。默认情况下,MySQL的端口号是3306
    • master_user='mercurows':指定连接到主数据库的用户名,这里用户名是 mercurows。这个就是上面主数据库中刚刚创建的用户
    • master_password='5508769123':这是指定连接到主数据库的用户的密码,这里密码是 5508769123
    • master_log_file='DESKTOP-UPK0D57-bin.000038':这是指定主数据库上用于复制的二进制日志文件的名称。在主从复制中,主数据库会将更改记录在二进制日志文件中,从数据库会从这些文件中读取并应用这些更改。而这个日志名称在上面的3.1中的4.检查主库状态中得出
    • master_log_pos=1353:这是指定从哪个位置开始读取主数据库的二进制日志文件。而这个位置在上面的3.1中的4.检查主库状态中得出

    image-20231007152446485

  4. 检查

    show slave status \G;
    

    image-20231007152624652

slave机器上有两个关键的进程,必须两个都要显示为 Y E S YES YES,一个是Slave_IO_Running:,一个是Slave_SQL_Running:一个负责与主机的io通信,一个负责自己的slave mysql进程。

3.3 测试

初始数据库情况:image-20231007153210127

mysql–主库,slave–从库

  1. 在主库中创建testdatabase数据库然后刷新从库:

image-20231007153357739

  1. 在主库创建user表并刷新从库

image-20231007153643507

经测试,对主库的增删改均能同步到从库中。

参考

  1. 如何在Windows上更改Docker的默认安装路径?
  2. docker搭建mysql8主从复制(一主一从)

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Django 前端模板显示换行符、日期格式

linebreaksbr 显示换行符 <td>{{ data.sku_list|default:"无"|linebreaksbr }}</td> date:"Y年m月d日 H:i" 设置日期格式 <td>{{ data.submit_time|date:"Y年m月d日 H:i" }}</td> 其他语法 forloop 获取循环的索引 …

从0开始学go第五天

gin框架返回JSON package mainimport ("net/http""github.com/gin-gonic/gin" )func main() {r : gin.Default()r.GET("/json", func(c *gin.Context) {//用map序列化//方法一&#xff1a;用map&#xff0c;后面用接口类型// data : map[string…

Golang网络编程:即时通讯系统Instance Messaging System

系统基本架构 版本迭代 项目改造 无人机是client&#xff0c;我们是server&#xff0c;提供注册登入&#xff0c;场景选择等。信道模拟器是server&#xff0c;我们是client&#xff0c;我们向信道模拟器发送数据&#xff0c;等待信道模拟器计算结果&#xff0c;返回给无人机。…

Altium Designer培训 | 2 - 原理图库创建篇

目录 原理图界面屏幕放大&缩小&移动 元件库介绍及电阻容模型的创建 【SCH Library】面板 元件符号 绘制一只电阻的模型 设置栅格大小 绘制一只电容的模型 IC类元件模型的创建 排针类元件模型的创建 光耦及二极管元件模型 现有元件模型的调用 参考上一篇文章…

jira+confluence安装

准备如下所有包&#xff1a; atlassian-agent.jar jdk-8u241-linux-x64.tar.gz atlassian-confluence-8.0.0-x64.bin atlassian-jira-software-9.4.0-x64.bin mysql-8.0.31-1.el8.x86_64.rpm-bundle.tar mysql-connector-java-8.0.28.jar confluence-8.2.1破解 1.安装j…

yolov5 web端部署进行图片和视频检测

目录 1、思路 2、代码结构 3、代码运行 4、api接口代码 5、web ui界面 6、参考资料 7、代码分享 1、思路 通过搭建flask微型服务器后端&#xff0c;以后通过vue搭建网页前端。flask是第一个第三方库。与其他模块一样&#xff0c;安装时可以直接使用python的pip命令实现…

【audio】alsa pcm音频路径

文章目录 AML方案音频路径分析dump alsa pcm各个音频路径的原始音频流数据 AML方案音频路径分析 一个Audio Patch用来表示一个或多个source端到一个或多个sink端。这个是从代码的注释翻译来的&#xff0c;大家可以把它比作大坝&#xff0c;可以有好几个入水口和出水口&#xf…

【Kotlin精简】第1章 基础类型

1 Kotlin基础类型 Kotlin中&#xff0c;我们可以调用任何变量的成员函数和属性&#xff0c;从这个角度来说&#xff0c;一切皆对象。某些类型可以有特殊的内部表现。例如&#xff1a;数字、字符和布尔型在运行时可以表现为基础类型&#xff08;primitivetypes&#xff09;。 …

架构师选择题--计算机网络

架构师选择题--计算机网络 22年考题21年考题20年考题19年真题2017考题 22年考题 d http:80 https:httpssl &#xff1a;443 b b pop3是邮件接收协议&#xff1a;110 SMTP是邮件发送协议&#xff1a;25 http:80 A 网络隔离&#xff1a;防火墙&#xff08;逻辑&#xff09;&…

五.docker+jenkins自动部署项目

一.敏捷开发相关概念 1.微服务的痛点 再来看一下我们的微服务架构 &#xff0c; 每个组件都需要服务器去部署&#xff0c;加起来可能需要几十个甚至上百个服务器。这样的微服务项目在部署上会遇到什么问题&#xff1f; 需要很多很多的服务器&#xff0c;服务器的采购安装&am…

【iOS】——仿写计算器

文章目录 一、实现思路二、实现方法三、判错处理 一、实现思路 先搭建好MVC框架&#xff0c;接着在各个模块中实现各自的任务。首先要创建好UI界面&#xff0c;接着根据UI界面的元素来与数据进行互动&#xff0c;其中创建UI界面需要用到Masonry布局。 二、实现方法 在calcu…

【C++面向对象侯捷下】4. pointer-like classes,关于智能指针 | 5. function-like classes,所谓仿函数

文章目录 4. pointer-like classes,关于智能指针pointer-like classes,关于智能指针 shared_ptrpointer-like classes,关于迭代器5. function-like classes&#xff0c;所谓仿函数【不懂&#xff0c;跳过】 4. pointer-like classes,关于智能指针 pointer-like classes,关于智…