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 ...
 
随机推荐
- Rabbit MQ的几种模式
			
RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件). 官网文档:https://www.rabbitmq.com/getstarted.html Rabbi ...
 - mysql中的InnoDB和MyISAM
			
InnoDB:支持事务,支持表级锁,行级锁,支持外键,是非聚集索引. MyISAM:不支持事务,支持表级锁,不支持外键,聚集索引. 聚集索引和非聚集索引的区别:InnoDB是聚集索引,使用B+Tree ...
 - 重磅!Cloud Ace 首度于德国设立法人,作为拓展Google Cloud 欧洲整合市场的基础
			
[Cloud Ace - 谷歌云 | 亚太地区最多据点的Google Cloud经销商 ] Cloud Ace, Inc.(总部:东京都千代田区,代表:青木诚,以下简称 Cloud Ace)在20 ...
 - PyCharm的安装使用
			
一.安装 1.进入官网点击下载 2.打开文件夹 3.点击next 4.选择安装路径 5.勾选创建桌面图标选项,点击next 6.点击安装 二.使用 1.import pycharm setting是指 ...
 - pip install -r 是什么意思
			
我们经常使用python安装第三方库的的命令是 pip install xxx; 但是有一天,突然要执行的命令是: pip install -r requirements.txt,突然就不知道是什么意 ...
 - ubuntu22.04安装 kubernetes(docker)
			
初始化检查 操作系统:ubuntu22.04 LTS docker:20.10.18 kubelet: v1.23.6 kubeadm:v1.23.6 kubectl: v1.23.6 1.校准时间: ...
 - perf 编译失败
			
linux-6.0-rc2 : linux-6.0-rc2/tools/include/asm/../../arch/x86/include/asm/rmwcc.h:7:9: error: impli ...
 - Redis实战(三)Redis冷备如何做
			
Redis 的 RDB 持久化方案,相信大家都有所了解,但是对于企业来说,如果只是持久化了一个 RDB 文件,不足以应付生产级别的事故.通常的方案就是对 RDB 进行多个备份,今天带大家来真枪实弹操作 ...
 - docker中搭建Ubuntu:16.04+python3.6+django环境
			
用vim 新建一个Dockerfile和sources.list文件,在里面添加如下内容. #sources.list deb http://mirrors.163.com/ubuntu/ xenia ...
 - 嵌入式Linux应用开发
			
3-4 Makefile常用的函数 i. $(foreach var,list,text) 简单地说,就是 for each var in list, change it to text. 对lis ...
 
			
		
