加入收藏 | 设为首页 | 会员中心 | 我要投稿 开发网_新乡站长网 (https://www.0373zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

应用搭建——docker环境下构建mysql数据库PXC集群

发布时间:2022-11-23 11:29:53 所属栏目:MySql教程 来源:
导读:  前几天实验室项目需要基于docker构建一个mysql的pxc集群,由于之前并不熟悉docker环境,特地花费了半天时间学习并基于dokcer构建出pxc数据集群。

  文章将对构建过程进行重新梳理,希望能帮助到更多有需要
  前几天实验室项目需要基于docker构建一个mysql的pxc集群,由于之前并不熟悉docker环境,特地花费了半天时间学习并基于dokcer构建出pxc数据集群。
 
  文章将对构建过程进行重新梳理,希望能帮助到更多有需要的人。
 
  1.基本指令
 
  构建项目时用到的基本指令
 
  docker容器相关指令
 
  2.PXC简介
 
  PXC全称是Percona XtraDB Cluster, 是著名的mysql公司Percona出品的免费的数据库集群产品。
 
  PXC主要用于解决MySQL集群中数据同步强一致性的问题。
 
  PXC是MySQL集群方案中公认的优先方案之一
 
  2.1 PXC的特点
 
  同步复制,事务在所有集群节点提交成功,要么不成功。
 
  多主复制,pxc集群环境之下各个结点都可读可写,实现了数据的双向同步处理。
 
  数据同步的强一致性mysql集群,所有节点数据保持一致。
 
  3.构建pxc集群
 
  基于docker构建数据库pcx集群大概有如下几个步骤:
 
  1.配置docker网络信息
 
  2.创建docker卷
 
  3.拉取pxc集群镜像信息
 
  4.配置选项信息,启动容器
 
  3.1 配置docker网络信息
 
  docker network create --subnet=172.30.0.0/24 pxc-network
 
  3.2 创建docker 卷
 
  3.3 拉去pxc镜像文件信息
 
  docker pull percona/percona-xtradb-cluster:5.7
 
  此处拉取pxc镜像时,尽量指定该版本信息,在构建过程用过其它版本,但是仅能启动一个结点信息,后续节点无法正常启动。
 
  其它版本笔者不敢肯定能否构建成功,为了确保能顺利构建,还望选择5.7版本。
 
  3.4 辅助操作
 
  为了便于后续信息的配置,此时对下载的镜像进行一次重命名操作
 
  docker tag :标记本地镜像,将其归入某一仓库。
 
  docker tag percona/percona-xtradb-cluster:5.7 pxc
 
  3.5 创建pxc容器
 
  创建容器使用docker run命令进行容器启动操作,下面对参数进行介绍
 
  首先指定端口映射规则,之后-v指定docker卷的映射信息,随后指定pxc集群内mysql的数据库密码 ,--name指定集群节点的名称 --net ,--ip分别指定出容器的网络,网卡信息。
 
  总结来看:端口信息,网路信息,数据映射信息,数据库密码信息,结点名称
 
  配置信息:
 
  #第一节点
 
  docker run -d -p 13306:3306 -v v1:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -e CLUSTER_NAME=pxc --name=pxc_node1 --net=pxc-network --ip 172.30.0.2 pxc
 
  #第二节点(增加了CLUSTER_JOIN参数)
 
  docker run -d -p 13307:3306 -v v2:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -e CLUSTER_NAME=pxc --name=pxc_node2 -e CLUSTER_JOIN=pxc_node1 --net=pxc-network --ip 172.30.0.3 pxc
 
  #第三节点(增加了CLUSTER_JOIN参数)
 
  docker run -d -p 13308:3306 -v v3:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -e CLUSTER_NAME=pxc --name=pxc_node3 -e CLUSTER_JOIN=pxc_node1 --net=pxc-network --ip 172.30.0.4 pxc
 
  特别注意:容器的启动应该顺次进行,当启动第一个结点时,需要初始化内部mysql信息,这个过程需要等待一段时间,才能进行后续操作。
 
  可以通过navicate的连接来判断是否初始完成
 
  判断是否初始化完成
 
  总结
 
  顺次执行完上述容器启动语句即可完成pxc集群的初始化,随后便可通过navicate连接到启动的mysql信息,进行数据同步的检验了。
 
  当在任意结点中创建一张表或向表中添加数据的操作,会同步到其它结点和表中。这样表明我们的pxc集群环境基本搭建完成!
 
  本文完全为自己构建时 ,一行一行亲自试验过的,真实可靠。希望能帮助到你。
 
  努力的路上并不孤独,你我一起努力,共勉~
 

(编辑:开发网_新乡站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!