MySQL高可用集群搭建
MySQL集群搭建在实际项目中还是非常必须的,我们通过PXC【Percona XtraDB Cluster】来实现强一致性数据库集群搭建。
2.1.1 MySQL集群搭建
1> 拉去镜像
docker pull percona/percona-xtradb-cluster:5.7.21
2> 复制pxc镜像【重命名】
docker tag percona/percona-xtradb-cluster:5.7.21 pxc
3>删除原来的镜像
docker rmi percona/percona-xtradb-cluster:5.7.21
4>创建单独的网段,给MySQL数据库集群使用
docker network create --subnet=172.20.0.0/24 pxc-net
docker network inpsect pxc-net # 查看详情
docker network rm pxc-net # 删除网段
5> 创建和删除volume
docker volume create --name v1 # 创建 volume
docker volume rm v1 # 删除volume
docker volume inspect v1 # 查看详情
6> 搭建pxc集群
准备三个数据卷
docker volume create --name mysql1
docker volume create --name mysql2
docker volume create --name mysql3
运行3个PXC容器
创建第一个节点
docker run -d -p 3301:3306 -v mysql1:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e EXTRABACKUP_PASSWROD=123456 --privileged --name=node1 --net=pxc-net --ip 172.20.0.2 pxc
mysql1:/var/lib/mysql :挂载路径和映射关系
CLUSTER_NAME=PXC :集群名字为PXC
EXTRABACKUP_PASSWORD=123456:数据库同步需要用到的密码为123456
MYSQL_ROOT_PASSWORD=123456 : mysql的登录密码,
--name=node1 节点名称为node1,
--net=pxc-net 节点指定的网段
--ip 节点分配的ip
创建第二个和第三个节点: 注意 -e CLUSTER_JOIN=node1 指定集群环境
docker run -d -p 3302:3306 -v mysql2:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e EXTRABACKUP_PASSWROD=123456 -e CLUSTER_JOIN=node1 --privileged --name=node2 --net=pxc-net --ip 172.20.0.3 pxc
docker run -d -p 3303:3306 -v mysql3:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e EXTRABACKUP_PASSWROD=123456 -e CLUSTER_JOIN=node1 --privileged --name=node3 --net=pxc-net --ip 172.20.0.4 pxc
查看是否启动成功
测试连接
搭建成功 创建一个docker-test测试的数据库,其余数据库同步出现