1.创建mysql集群
下载pxc镜像
docker pull percona/percona-xtradb-cluster
创建内部网络:出于安全考虑,需要给PXC集群实例创建Docker内部网络
创建命令:docker network create net1
创建指定网段:docker network create --subnet=172.18.0.0/24 net1
查看网络属性:docker network inspect net1
删除网络:docker network rm net1

创建docker卷(容器中的PXC节点映射数据目录的解决办法)
docker volume create --name v1

创建PXC容器(只需要像PXC镜像传入运行参数就能创建出PXC容器)
node1节点:
docker run -d -p 3306:3306 \
-v v1:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=数据库密码 \
-e CLUSTER_NAME=PXC \
-e XTRABACKUP_PASSWORD=数据库节点之间同步的密码 \
--privileged --name=node1 --net=net1 --ip=172.18.0.0/24 pxc

node2到node5节点
docker run -d -p 3306:3306 \
-v v1:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=数据库密码 \
-e CLUSTER_NAME=PXC \
-e XTRABACKUP_PASSWORD=数据库节点之间同步的密码 \
-e CLUSTER_JOIN=node1 \
--privileged --name=node# --net=net1 --ip=172.18.0.0/24 pxc

2.数据库负载均衡:
下载haproxy镜像
docker pull haproxy
docker images查看镜像
创建Haproxy配置文件
在宿主机上创建:touch /home/soft/haproxy.cfg
配置文件可以参考:https://zhangge.net/5125.html