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%';
显示三个节点都连接成功
集群同步测试
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也会将修改后的数据同步。
虚拟机要关闭防火墙或者放行,买的服务器要开放安全策略