使用docker搭建mysql集群

news2025/1/22 17:03:54

一、技术架构

  • 1、架构图

    在这里插入图片描述

  • 2、解说

    • mysql_1mysql_2mysql_3是一组主从模式,同理mysql_4mysql_5mysql_6也是一组主从模式
    • 从上面的图可以看出mysql_1mysql_4是主节点,可以进行增删改查操作,但是子几点只能查询操作
    • 如果mysql_1节点出现问题了,有mysql_4节点组正常工作

二、创建MYSQL_1节点

  • 1、使用镜像创建容器

    docker run -it -d --name mysql_1 -p 7001:3306 \
    --net mynet --ip 172.18.0.2 \
    -m 400m -v /root/mysql_1/data:/var/lib/mysql  \
    -v /root/mysql_1/config:/etc/mysql/conf.d  \
    -e MYSQL_ROOT_PASSWORD=abc123456  \
    -e TZ=Asia/Shanghai --privileged=true  \
    mysql:5.7  \
    --lower_case_table_names=1
    
  • 2、查看容器是否启动成功

  • 3、在本地使用navicat连接远程数据库,创建一个用户

    在这里插入图片描述

  • 4、给当前用户分配权限

在这里插入图片描述

  • 5、停止当前的容器,添加配置文件,然后上传到服务器/root/mysql_1/config目录下

    [mysqld]
    # 数据库字符集
    character_set_server = utf8
    # mysql编号(只可以是数字) 每个节点不一样
    server_id = 1
    # 开始binlog日志,规定日志文件名称
    log_bin = mysql_bin
    # 开启relaylog日志,规定日志文件名称
    relay_log = relay_bin
    # 从库的写操作是否写入binlog日志
    log-slave-updates = 1
    # 采用严格的SQL语句模式
    sql_mode = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
    
  • 6、重启容器

    docker start mysql_1
    

三、创建MYSQL_2节点数据库

  • 1、创建数据库容器

    docker run -it -d --name mysql_2 -p 7002:3306 \
    --net mynet --ip 172.18.0.3 \
    -m 400m -v /root/mysql_2/data:/var/lib/mysql  \
    -v /root/mysql_2/config:/etc/mysql/conf.d  \
    -e MYSQL_ROOT_PASSWORD=abc123456  \
    -e TZ=Asia/Shanghai --privileged=true  \
    mysql:5.7  \
    --lower_case_table_names=1
    
  • 2、查看是否创建成功

  • 3、停止MYSQL_2节点,,添加配置文件,然后上传到服务器/root/mysql_2/config目录下

    [mysqld]
    # 数据库字符集
    character_set_server = utf8
    # mysql编号(只可以是数字) 每个节点不一样
    server_id = 2
    # 开始binlog日志,规定日志文件名称
    log_bin = mysql_bin
    # 开启relaylog日志,规定日志文件名称
    relay_log = relay_bin
    # 限制普通账户无法insert、delete、update语句,但是该配置对于管理员账号无效
    read-only = 1
    # 采用严格的SQL语句模式
    sql_mode = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
    
  • 4、启动容器

  • 5、测试是否同步

    # 停止数据同步服务
    stop slave;
    # 设置mysql_1数据库同步
    change master to master_host="172.18.0.2",master_port=3306,master_user='sync',master_password='abc123456';
    # 启动服务
    start slave;
    # 查看同步状态
    show slave status;
    

    在这里插入图片描述

四、创建MYSQL_3节点和上面MYSQL_2节点步骤一样的

五、创建MYSQL_4节点和上面MYSQL_1节点步骤一样的

六、创建MYSQL_5MYSQL_6节点和上面创建MYSQL_2MYSQL_3一样的

七、直接在MYSQL_1中随便创建一个数据库,刷新MYSQL_2MYSQL_3查看数据库是否同步,同理MYSQL_4MYSQL_5MYSQL_6也是一样的

八、MYSQL_1MYSQL_4进行关联

  • 1、MYSQL_1MYSQL_4相互关联

  • 2、在MYSQL_1的查询中执行以下语句,注意这个地方是要关联到mysql_4ip地址

    # 停止数据同步服务
    stop slave;
    # 设置mysql_1数据库同步
    change master to master_host="172.18.0.5",master_port=3306,master_user='sync',master_password='abc123456';
    # 启动服务
    start slave;
    # 查看同步状态
    show slave status;
    
  • 3、在mysql_4中执行以下语句,查看状态

    # 停止数据同步服务
    stop slave;
    # 设置mysql_1数据库同步
    change master to master_host="172.18.0.2",master_port=3306,master_user='sync',master_password='abc123456';
    # 启动服务
    start slave;
    # 查看同步状态
    show slave status;
    
  • 4、在任何一个数据库中创建一个一个数据库和数据表,查看别的是否同步

  • 5、参考文章

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

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

相关文章

Python:使用prometheus-client提交数据到实现prometheus+ grafana数据监控

相关资料 prometheus文档:https://prometheus.io/grafana文档:https://grafana.com/grafana github: https://github.com/grafana/grafanaPyhton客户端https://pypi.org/project/prometheus-client/ 目录 1、使用Python提供数据源2、启动 prometheus3、…

eDNA暴露人类活动轨迹!你的DNA信息可能随时随地在泄露!

环境DNA(environmental DNA, eDNA)领域发展迅速,但人类eDNA的应用仍未得到充分利用和重视。eDNA分析的广泛应用将为病原体监测、生物多样性监测、濒危和入侵物种检测以及群体遗传学带来许多公认的好处。 佛罗里达大学野生动物疾病基因组学教…

【pytorch函数笔记】torch.sum()、torch.unsqueeze()

1.torch.sum torch.sum(imgs, dim0) # 按列求和 torch.sum(imgs, dim1) # 按行求和 imgs torch.Tensor([i for i in zip( range(10), range(10))]) print(imgs) s1torch.sum(imgs, dim0) # 按列求和 s2torch.sum(imgs, dim1) # 按行求和 print(s1) print(s2) 2.torch.uns…

在前端开发中使用 Python

推荐给需要鼓捣前端应用又不熟悉 JS 的 Pythoner 简介 在使用 Python 进行数据分析的时候,经常需要创建一些动态、交互式的可视化作品。一般会用到如 Plotly、Pyecharts、Bokeh 等库,这些库都是基于前端技术创建可视化作品。所以在自定义可视化的时候&a…

Python3,有了此库,不需要再为导包顺序而烦恼了,小刀拉屁股,涨知识了。

usort详解 1、引言2、代码实战2.1 usort 安装2.2 代码示例 3、总结 1、引言 小鱼:小屌丝,这段代码是你的写的不? 小屌丝:是我写的啊,咋 鱼哥 小鱼:你看你的导包顺序,挺乱的 小屌丝:…

一些共享资料

大家好,才是真的好。 我们好久没有分享资料了,上次分享还是上次——我也忘记了多久。 本次Engage2023开完之后,从会议上也流出了很多各类技术和主题方面的PPT、PDF资料等,我搜索了一些Domino技术话题有关的共享在这里。 主题涉…

算法----二叉树的最近公共祖先

题目 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它…

轻量服务器外网访问不了的原因分析

​  轻量服务器外网访问不了原因的分析。很多用户在选择轻量服务器的时候都没考虑,直接就购买了,导致在使用的时候遇见了很多问题,下面我们就简单的聊聊关于轻量服务器外网无法访问的原因。 这里我们按照标题的意思可以解读为两种情况&…

2023最新互联网公司时长排行榜出炉

今天给大家分享一个对于选择公司来说另一个非常重要的参考指标:“互联网时长”。 我们在选择一个公司的时候,除了需要关注总收入package 以外,还需要考虑这家公司的加班时长是否人性化。 我们的工作时长是周工作小时数。法定工作时间是40小…

这8种Python加速运行技巧真棒

关注“Python专栏”微信公众号,回复暗号【面试大全】,立即领取面试题简历模板。 Python 是一种脚本语言,相比 C/C 这样的编译语言,在效率和性能方面存在一些不足。但是,有很多时候,Python 的效率并没有想象…

使用wpf做得计算器

最近在学习wpf,使用wpf做得计算器练手,实现功能增删改查,求平方根,倒数,取反,模拟实体计算器的M,MS,MC,MR功能 上面截图相关的计算为 8乘5加-2加3.2加(9除以3的余数)

一路乱飙,从手工测试进阶测试开发岗,“我“的测试之路不简单

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 测试人员的职能 …

StrSubstitutor和StrUtil占位符字符串替换

目录 一、commons-lang包下的StrSubstitutor1、使用场景一2、使用场景二 二、hutoo包下的StrUtil1、使用场景一2、使用场景二3、使用场景三 三、原生的三种方式 一、commons-lang包下的StrSubstitutor StrSubstitutor是commons-lang包提供的一个字符串替换类,整体使…

Redis实战——短信登录(二)

Redis代替session redis中设计key 在使用session时,每个用户都会有自己的session,这样虽然验证码的键都是“code”,但是相互不影响,从而确保每个用户获取到的验证码只能够自己使用,当使用redis时,redis的ke…

MCU单片机智能控制落地扇解决方案

随着科技进步和消费升级,消费者对电风扇的智能化需求日趋强烈。为了快速响应市场需求,以更低的成本打造智能电风扇。 MCU单片机智能控制落地扇解决方案以灵动微MM32SPIN040C主控。 方案采用的主控MM32SPIN040工作频率可达48MHz,内置16KB Fl…

虹科分享 | 拒绝自燃和爆炸,AGV电池如何进行实时监控和预测性维护?

Automated Guided Vehicle简称AGV,通常也称为AGV小车、自动导引运输车或无人搬运车等,指装备有电磁或光学等自动导引装置,能够沿规定的导引路径行驶,具有安全保护以及各种移载功能的运输车,通常用可充电的蓄电池来作为…

JumpServer开源堡垒机安装配置

JumpServer开源堡垒机安装与配置 一、简介二、下载与安装2.1、下载2.2、安装2.3、其他 一、简介 JumpServer 堡垒机帮助企业以更安全的方式管控和登录各种类型的资产。 支持 官网地址:https://www.jumpserver.org/index.html JumpServer 采用分层架构,…

【SNMP服务】网络杂谈(11)之什么是SNMP服务?

#2023 博客之星评选已开启–成为城市领跑者# 涉及知识点 什么是 SNMP,SNMP的特点,SNMP的服务,SNMP服务运行。深入了解SNMP技术。 原创于:CSDN博主-《拄杖盲学轻声码》,更多内容可去其主页关注下哈,不胜感…

Vue启用unity3D的exe

🐰个人主页:张清悠 👦个人简介:张清悠,字澄澈,号寻梦客,爱好旅行、运动,主攻前端方向技术研发,副攻Unity 3D、C、Python人工智能等 📝个人寄语:学…

parcel运行终端报错Uncaught ReferenceError: parcelRequire is not defined解决方案

我们通过指令 npm install parcel-bundler安装的parcel 运行起来会有一个报错 换个版本就好了 打开项目终端 我们先执行 npm uninstall parcel-bundler将错误的版本给他干掉 然后执行 npm install parcel安装正确的版本 然后运行项目 在浏览器中访问地址就一切正常了