docker安装mysql(PXC)集群

mysql集群的两种方案:

方案一:Replication 方案

特点:速度快、弱一致性、低价值数据

适合存储的数据:日志、新闻、帖子


方案二:PXC 方案(percona-xtradb-cluster首字母)

特点:速度慢、强一致性、高价值数据 

适合存储的数据:订单、账户、财务

dockerhub的地址:https://hub.docker.com/r/percona/percona-xtradb-cluster/

先下载集群镜像命令:如果下载很慢则 配置一下国内镜像加速地址

如果你发现docker search 总是超时看我另外一篇博客应该能解决问题

docker pull percona/percona-xtradb-cluster

为了方便给该镜像取个别名叫pxc

docker tag percona/percona-xtradb-cluster pxc

假设要创建5个mysql服务节点的集群,需要准备5个容器,使用的是docker内部的网络,因为docker没有认证的步骤,所以docker的安全性是建立在linux操作系统上的安全性。docker自带的网段是 172.17.0.x

 创建docker网络 需要制定子网,不然启动容器会报错

你需要查看(docker network ls 看有那几张网卡然后通过docker network inspect 网卡名 查看子网例如下面的图片)默认的几张网卡,防止下面的子网ip陪使用了,如果被使用了则换一个比如172.19.0.0.4/24

docker network create --subnet=172.18.0.0/24 net1

创建5个数据卷

创建数据卷(原因是mysql应用可能会出问题,但是数据我想保存下来,则需要把数据放到宿主机上)

docker volume create --name v1

接着创建四个数据卷

docker volume create --name v2
docker volume create --name v3
docker volume create --name v4
docker volume create --name v5

启动容器

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -v v1:/var/lib/mysql --privileged --name=node1 --net=net1 --ip 172.18.0.2 --restart=always pxc

 方便复制:直接复制下面的就行

docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -v v1:/var/lib/mysql --privileged --name=node1 --net=net1 --ip 172.18.0.2 --restart=always pxc

这里一定不要急!每启动一个MySQL就要等它初始化完成后,并且能用Navicat等客户端 连接上MySQL再继续启动下一个MySQL、尤其是第一个服务器和后面的几个,还有就是注意参数不要弄错了,所以建议复制我测试好的命令,直接运行。

 解释一下这里的参数

-d 表示后台运行,-p 将宿主机端口和容器端口映射。

-e 表示启动参数,这里有3个参数所以用3个-e

第一个是root密码,第二个是集群的名称,第三个是同步密码

-v 映射数据卷v1到容器中的/var/lib/mysql

--privileged 最高权限执行,--name取别名。--net=net1指定网卡net1

--ip 指定ip为 172.18.0.2

--restart=always  开机自启

pxc是使用的镜像名(前面重命名了tag)

接着启动剩下的容器,在上面基础上需要修改一下参数,因为上面的mysql占用了宿主机的端口,还有剩下的mysql指定加入到集群中   

需要和前面的命令做对比,修改了使用宿主机端口,加了CLUSTER_JOIN参数,修改了使用的数据卷,修改了使用的子网ip

docker run -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=node1 -v v2:/var/lib/mysql --privileged --name=node2 --net=net1 --ip 172.18.0.3 --restart=always pxc

方便复制

docker run -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=node1 -v v2:/var/lib/mysql --privileged --name=node2 --net=net1 --ip 172.18.0.3 --restart=always pxc

第三到第5个 mysql容器

docker run -d -p 3308:3306 -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=node1 -v v3:/var/lib/mysql --privileged --name=node3 --net=net1 --ip 172.18.0.4 --restart=always pxc
docker run -d -p 3309:3306 -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=node1 -v v4:/var/lib/mysql --privileged --name=node4 --net=net1 --ip 172.18.0.5 --restart=always pxc
docker run -d -p 3310:3306 -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=node1 -v v5:/var/lib/mysql --privileged --name=node5 --net=net1 --ip 172.18.0.6 --restart=always pxc

 

额外篇

为了测试自己的集群服务器是否是正常工作的,首先通过Navicat链接上5个MySQL服务器如图


 测试一下创建表,并且插入数据试试

 


 测试一下双向同步策略

 

发现同步过来了 ,说明有效,集群正常工作

 

后续篇:docker下 mysql数据库集群 使用Haproxy负载均衡

 

 

以下是创建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
发出的红包

打赏作者

诗水人间

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值