docker 安装 MySql数据库PXC集群

本文档介绍了如何通过Docker来安装和配置Percona XtraDB Cluster MySQL集群。首先,从Docker Hub下载percona/percona-xtradb-cluster镜像。然后,创建并命名网络,确保没有地址冲突。接着,创建数据卷以持久化存储数据库数据,并为集群设置热备份。最后,启动多个MySQL节点,设置环境变量如MYSQL_ROOT_PASSWORD、CLUSTER_NAME、XTRABACKUP_PASSWORD等,连接到同一网络,并分配不同的IP地址。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下载My Sql 镜像

docker pull percona/percona-xtradb-cluster
网络下载需要些时间耐心等待

docker pull percona/percona-xtradb-cluster:5.7.21

查看本地镜像

docker images

输出

percona/percona-xtradb-cluster   5.7.21    f1439de62087   3 years ago   413MB

镜像名称太长了,进行改名:

docker tag percona/percona-xtradb-cluster:5.7.21 pxc:5.7.21
docker rmi percona/percona-xtradb-cluster:5.7.21 

网络管理

docker network ls 查看网络信息
docker network create --subnet=网段 网络名称
docker network rm 网络名称

创建net1网段

docker network create --subnet=172.18.0.0/24 net1

如果出现网段重叠就换一个网段
docker network create --subnet=172.19.0.0/24 net1
Error response from daemon: Pool overlaps with other one on this address space^C

docker network create net1
docker network inspect net1
docker network rm net1

数据卷管理

docker volume create 数据卷名称  #创建数据卷
docker volume rm 数据卷名称  #删除数据卷
docker volume inspect 数据卷名称  #查看数据卷

创建5个数据卷

docker volume create --name mysql1
docker volume create --name mysql2
docker volume create --name mysql3
docker volume create --name mysql4
docker volume create --name mysql5

创建备份数据卷(用于热备份数据)

docker volume create --name mysqlbackup

查看docker 数据卷

docker volume ls

查看mysql1 数据卷详情

docker inspect mysql1

删除docker 数据卷

docker volume rm v1

删除没用的卷:

 docker volume prune 

创建第1个MySQL节点

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=0987POIUwow -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=0987POIUwow  -e TZ=Asia/Shanghai -v mysql1:/var/lib/mysql -v mysqlbackup:/data --privileged --name=node1 --net=net1 --ip 172.18.0.2 pxc:5.7.21 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=0987POIUwow -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=0987POIUwow -e TZ=Asia/Shanghai -v mysql1:/var/lib/mysql --privileged --name=node1 --net=net1 --ip 172.18.0.2 pxc:5.7.21 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=0987POIUwow -e CLUSTER_NAME=PXC -e TZ=Asia/Shanghai -v mysql1:/var/lib/mysql -v mysqlbackup:/data --privileged --name=node1 --net=net1 --ip 172.18.0.2 pxc:5.7.21 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=0987POIUwow -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -v v1:/var/lib/mysql -v backup:/data --privileged --name=node1 --net=net1 --ip 172.18.0.2 pxc:5.7.21

以下是创建MySQL 8的PXC集群的步骤: 1.安装DockerDocker Compose 在安装Docker之前,需要先卸载旧版本的Docker。然后,按照相应的操作系统的指引安装最新版本的DockerDocker Compose。 2.创建Dockerfile 创建Dockerfile,以便Docker能够构建MySQL 8的PXC镜像。下面是一个示例Dockerfile: ``` FROM mysql:8.0 RUN apt-get update && apt-get install -y wget gnupg2 RUN wget https://repo.percona.com/apt/percona-release_latest.$(lsb_release -sc)_all.deb RUN dpkg -i percona-release_latest.$(lsb_release -sc)_all.deb RUN apt-get update && apt-get install -y percona-xtradb-cluster-57 COPY my.cnf /etc/mysql/my.cnf CMD ["mysqld"] ``` 3.创建docker-compose.yml文件 在docker-compose.yml中定义PXC集群的服务。下面是一个示例docker-compose.yml文件: ``` version: '3' services: db1: image: mysql-pxc hostname: db1 ports: - "3306:3306" volumes: - /data/mysql/db1:/var/lib/mysql environment: - MYSQL_ROOT_PASSWORD=root - CLUSTER_NAME=mycluster - CLUSTER_JOIN=db1,db2,db3 db2: image: mysql-pxc hostname: db2 volumes: - /data/mysql/db2:/var/lib/mysql environment: - MYSQL_ROOT_PASSWORD=root - CLUSTER_NAME=mycluster - CLUSTER_JOIN=db1,db2,db3 db3: image: mysql-pxc hostname: db3 volumes: - /data/mysql/db3:/var/lib/mysql environment: - MYSQL_ROOT_PASSWORD=root - CLUSTER_NAME=mycluster - CLUSTER_JOIN=db1,db2,db3 ``` 4.构建和启动PXC集群 使用以下命令构建和启动PXC集群: ``` docker-compose up --build -d ``` 5.验证PXC集群 使用以下命令验证PXC集群是否正常工作: ``` docker exec -it pxc_db1 mysql -uroot -proot -e "SHOW STATUS LIKE 'wsrep_cluster_size'" ``` 如果输出结果是3,那么就表示PXC集群已经成功创建。 以上就是创建MySQL 8的PXC集群的步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值