Docker 中部署mysql PXC集群

Docker 中部署mysql PXC集群

搭建PXC 集群

1. 下载docker镜像

docker pull percona/percona-xtradb-cluster:5.7

2.重命名镜像名称

docker tag percona/percona-xtradb-cluster:5.7 pxc:5.7docker 
docker tag percona/percona-xtradb-cluster:5.7 pxc:5.7

3.删除原始镜像

docker rmi percona/percona-xtradb-cluster:5.7

4.创建 Docker 网络,用于 PXC 集群独立使用

docker network create pxc-network

5.创建数据卷用于之后挂载

docker volume create --name v1
docker volume create --name v2
docker volume create --name v3

6.创建第一个节点

docker run -di --name=pxc1 --net=pxc-network -p 9000:3306 -v v1:/var/lib/mysql --privileged -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=cluster1 -e XTRABACKUP_PASSWORD=123456  pxc:5.7 

因为后续节点的添加需要关联到第一个节点,所以需要等待数据库启动完成。通过 docker logs pxc1 查看日志,如果出现下面的输出,证明启动成功:

2022-10-08T05:48:36.895062Z 0 [Note] InnoDB: Buffer pool(s) load completed at 221008  5:48:36

7.添加第二个节点

docker run -di --name=pxc2 --net=pxc-network -p 9001:3306 -v v2:/var/lib/mysql --privileged -e MYSQL_ROOT_PASSWORD=123456  -e CLUSTER_NAME=cluster1 -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=pxc1 pxc:5.7 

需要注意是第二个节点开始需要增加 e CLUSTER_JOIN=pxc1 参数,表示与 pxc1 节点同步,否则 pxc1 容器会自动关闭。
当 PXC集群中存在两个节点以上之后就没有主节点的概念了。集群中最后一个退出的节点就会变为主节点,在/var/lib/mysql/grastate.dat 文件中属性 safe_to_bootstrap 的值 会从 0 被设置为 1 表示该节点是主节点。

8.添加第三个节点

docker run -di --name=pxc3 --net=pxc-network -p 9002:3306 -v v3:/var/lib/mysql --privileged -e MYSQL_ROOT_PASSWORD=123456  -e CLUSTER_NAME=cluster1 -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=pxc2 pxc:5.7  

可以看到我们这次我们 CLUSTER_JOIN 的是 pn2 容器,可以证明我们刚刚说的 当 PXC 集群存在两个节点以上之后就没有主节点.

9.进入 pxc 节点中任意 一个节点中

mysql -uroot -p123456 -h 宿主机ip -P9000
mysql -uroot -p123456 -h 宿主机ip -P9001
mysql -uroot -p123456 -h 宿主机ip -P9002

查看集群的状态

show status like 'wsrep%';

显示三个节点都连接成功

image-20221008163134443


集群同步测试

1.再节点一创建数据库(test)

mysql> create database test;
Query OK, 1 row affected (0.02 sec)

2、再另外两个节点查看

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
| test               |
+--------------------+
5 rows in set (0.00 sec)

宕机操作

1.把节点pxc3容器关闭,造成宕机现象

docker stop pxc3

2.再其他节点上做查看集群状态

mysql> show status like 'wsrep%';

可以看到集群应该有3个节点,但是现在只有2个正常连接。
在进行修改数据的操作,然后在在重新启动的pxc3,你会发现,pxc3也会将修改后的数据同步。

image-20221008163451304

image-20221008163515588

虚拟机要关闭防火墙或者放行,买的服务器要开放安全策略

以下是创建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集群的步骤。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值