用Docker搭建MySQL高可用集群

384 阅读2分钟

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测试的数据库,其余数据库同步出现