docker 中搭建 mysql pxc 集群
一、docker中创建pxc 容器
1.拉取PXC 镜像 pull
docker pull percona/percona-xtradb-cluster:5.7.21
2.更改镜像名称为pxc tag
docker tag percona/percona-xtradb-cluster:5.7.21 pxc
3.删除旧名称的镜像 rmi
docker rmi percona/percona-xtradb-cluster:5.7.21e
二、容器内部创建网段
1.创建容器内部网段 通过映射方式事项外部访问 network create
docker network create net1 2.查看网段的信息 inspect
docker network inspect net1
3.删除网段信息
docker network rm net1
4.自定义创建网段 参数 --subnet
docker network create --subnet=172.18.0.0.1/24 net1
5.查看net1网段信息 inspect
三、创建docker 卷
1.创建docker 数据卷 (pxc 数据不能储存在容器里,必须储存在宿主机上,所以集群不能直接使用路径映射,必选创建数据券,再将数据券映射到宿主机的目录)
docker volume create --name v1
2.查看数据卷位置
docker inspect v1
可以看到数据券创建成功,"Mountpoint": "/var/lib/docker/volumes/v1/_data",
创建PXC 数据库节点时只需要把这个是数据券在宿主机上的位置,只需要把v1 映射到宿主机的数据卷上就可以了
4.创建PXC 第一个容器
docker run -d -p 3306:3306 -v v1:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 --privileged --name=node1 --net=net1 --ip172.20.0.2 pxc
参数解释:
docker run -d (启动容器在后台运行)
-p 3306:3306 (断后映射前面为宿主机端口,后为容器端口)
-v v1:var/lib/mysql (路径映射卷)
-e MYSQL_ROOT_PASSWORD=abc123456 (数据库ROOT 用户密码)
-e CLUSTER_NAME=PXC (容器名称)
-e XTRABACKUP_PASSWORD=abc123456 (数据同步密码)
--privileged (最高权限) --name=node1 (容器节点名称)
--net=net1 (容器内部网段)
--ip172.18.0.2 (内部网段对应的ip)
pxc 容器名
4.1创建PXC 第二个容器
docker run -d -p 3307:3306 -v v2:/var/lib/mysql -e CLUSTER_JOIN=node1 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 --privileged --name=node2 --net=net1 --ip=172.20.0.3 pxc
参数解释:
docker run -d (启动容器在后台运行)
-p 3307:3306 (宿主机端口需要错开,后为容器端口)
-v v2:var/lib/mysql (路径映射卷)
-e MYSQL_ROOT_PASSWORD=abc123456 (数据库ROOT 用户密码)
-e CLUSTER_JOIN=node1 加入集群 和第一个容器节点数据库同步
-e CLUSTER_NAME=PXC (容器名称)
-e XTRABACKUP_PASSWORD=abc123456 (数据同步密码)
--privileged (最高权限)
--name=node2 (容器节点名称)
--net=net1 (容器内部网段)
--ip172.18.0.3 (内部网段对应的ip 需要错开)
pxc 容器名
4.2创建PXC 第三个容器
docker run -d -p 3308:3306 -v v3:/var/lib/mysql -e CLUSTER_JOIN=node1 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 --privileged --name=node3 --net=net1 --ip=172.20.0.4 pxc
参数解释:
docker run -d (启动容器在后台运行)
-p 3308:3306 (宿主机端口需要错开,后为容器端口)
-v v3:var/lib/mysql (路径映射卷)
-e MYSQL_ROOT_PASSWORD=abc123456 (数据库ROOT 用户密码)
-e CLUSTER_JOIN=node1 加入集群 和第一个容器节点数据库同步
-e CLUSTER_NAME=PXC (容器名称)
-e XTRABACKUP_PASSWORD=abc123456 (数据同步密码)
--privileged (最高权限)
--name=node3 (容器节点名称)
--net=net1 (容器内部网段)
--ip172.18.0.4 (内部网段对应的ip 需要错开)
pxc 容器名
5,第三个第四个容器
docker run -d -p 3309:3306 -v v4:/var/lib/mysql -e CLUSTER_JOIN=node1 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 --privileged --name=node4 --net=net1 --ip=172.20.0.5 pxc docker run -d -p 3310:3306 -v v5:/var/lib/mysql -e CLUSTER_JOIN=node1 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 --privileged --name=node5 --net=net1 --ip=172.20.0.6 pxc
docker 中搭建 mysql pxc 集群的更多相关文章
- 基于keepalived搭建MySQL热机集群
背景 MySQL的高可用方案一般有如下几种: keepalived+双主,MHA,MMM,Heartbeat+DRBD,PXC,Galera Cluster 比较常用的是keepalived+双主,M ...
- 抄来的,占个位儿【百度架构师是怎样搭建MySQL分布式集群】
1.准备集群搭建环境 使用6台虚拟机来搭建MySQL分布式集群,相应的实验环境与对应的MySQL节点之间的对应关系如下图所示: 管理节点(MGM):这类节点的作用是管理MySQLCluster ...
- MySQL PXC集群安装配置
1.关闭防火墙 [root@node04 ~]#systemctl disable firewalld [root@node04 ~]#systemctl stop firewalld [root@n ...
- docker中mysql pxc集群
PXC集群 https://hub.docker.com/r/percona/percona-xtradb-cluster 安装PXC镜像 下载镜像或者导入本地镜像 docker pull perco ...
- MySQL数据库高可用集群搭建-PXC集群部署
Percona XtraDB Cluster(下文简称PXC集群)提供了MySQL高可用的一种实现方法.集群是有节点组成的,推荐配置至少3个节点,但是也可以运行在2个节点上. PXC原理描述: 分布式 ...
- 使用Docker Swarm搭建分布式爬虫集群
https://mp.weixin.qq.com/s?__biz=MzIxMjE5MTE1Nw==&mid=2653195618&idx=2&sn=b7e992da6bd1b2 ...
- MySQL PXC集群部署
安装 Percona-XtraDB-Cluster 架构: 三个节点: pxc_node_0 30.0.0.196 pxc_node_1 30.0.0.198 pxc_node_2 30.0.0.19 ...
- Docker Compose 搭建 Redis Cluster 集群环境
在前文<Docker 搭建 Redis Cluster 集群环境>中我已经教过大家如何搭建了,本文使用 Docker Compose 再带大家搭建一遍,其目的主要是为了让大家感受 Dock ...
- Docker搭建MySQL主从集群,基于GTID
写在前边 搭建MySQL读写分离主从集群,这里未使用binlog方式,使用的是GTID方式 源码见我的Github https://github.com/hellxz/mysql-cluster-do ...
- docker mysql pxc集群(percona-xtradb-cluster)
docker pull percona/percona-xtradb-cluster docker tag percona/percona-xtradb-cluster pxc docker netw ...
随机推荐
- Linux 第六节( 磁盘系统,挂载,分区,格式化)
/dev/st0 磁带机 /dev/lp 打印机 /dev/cdrom 光驱 /dev/sd scsi接口硬盘 sata接口硬盘 U盘(sda,sdb,sdc 分别对应 ...
- FCOS网络(free anchor)
FCOS FCOS网络解析 FPN输出多个特征图,然后如何处理这些特征图? [问题]"特征图相对原图的步距是s"是个什么东西
- 路飞之-后台日志封装-前后端分离的rbac项目演示-全局异常处理封装-封装Response-luffy数据库创建-软件开发模式-User模块用户表-django的配置文件-开启media访问
目录 路飞之-后台日志封装-前后端分离的rbac项目演示-全局异常处理封装-封装Response-luffy数据库创建-软件开发模式-User模块用户表-django的配置文件-开启media访问 今 ...
- vue整体回顾
vue大回顾 1 前端发展史 react vue---> 前端工程化---> 前后端分离 大前端:flutter uni-app 2 Vue介绍 单页面应用(spa) 组件化开发 mvvm ...
- css可继承与不可继承的属性
一.可继承性的属性 字体相关的:font-size/font-family/font-weight/font-style/font-variant/font-stretch 文本相关的:color/t ...
- JAVA学习笔记-08
package: 对类文件进行分类管理 给类提供多层命令空间 写在程序文件第一行,包名全部字母小写 类名的全称是 包名.类名 包也是一种封装形式. 包与包之间的访问: 包与包之间进行访问,被访问的包 ...
- VIM的撤销与恢复设置行数
vim撤销操作:u vim恢复操作:ctrl+r 设置行数: :set nu
- centos 6.5 docker 安装
https://www.cnblogs.com/zhangzhen894095789/p/6641981.html?utm_source=itdadao&utm_medium=referral
- mysql在windows下安装
参考博客:https://blog.csdn.net/weixin_43423484/article/details/124408565
- 多线程学习(第二天)Java内存模型
一.内存模型基础 Java的并发采用的是共享内存模型,Java线程之间的通信总是隐式进行,整个通信过程对程序员完全透明. 如果编写多线程程序的Java程序员不理解隐式进行的线程之间通信的工作机制,很可 ...

