docker-mysql-pxc

–与 MySQL 不同的是 PXC 官方提供了 Docker 镜像,所以我们可以很方便的搭建 PXC 集群。
–下载docker mysql镜像
docker pull percona/percona-xtradb-cluster:5.7
–重命名镜像名称
docker tag percona/percona-xtradb-cluster:5.7 pxc:5.7
–删除原始镜像
docker rmi percona/percona-xtradb-cluster:5.7

docker network ls
–创建docker网络,用于pxc集群单独使用
docker network create pxc-network
–创建数据卷用于之后挂载
–pxc容器只支持数据卷挂载,不支持目录挂载
docker volume create --name v1
docker volume create --name v2
docker volume create --name v3

–创建第一个节点
docker run -di --name=pn1 --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 pn1
–创建第二个节点
–因为后续节点的添加需要关联到第一个节点
docker run -di --name=pn2 --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=pn1 pxc:5.7

–创建第三个节点
–当 PXC 集群存在两个节点以上之后就没有主节点的概念了
docker run -di --name=pn3 --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=pn2 pxc:5.7

–进入pn1节点
docker exec -it pn1 /usr/bin/mysql -uroot -p123456
docker exec -it pn2 /usr/bin/mysql -uroot -p123456
docker exec -it pn3 /usr/bin/mysql -uroot -p123456

–查看状态
mysql> show status like ‘wsrep%’;

–查看容器ip地址
docker inspect 容器id
docker ps
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES ip
ab7eaad1a09c pxc:5.7 “/entrypoint.sh my…” 5 seconds ago Up 3 seconds 4567-4568/tcp, 0.0.0.0:9002->3306/tcp pn3 172.18.0.4
fa0eec8621a0 pxc:5.7 “/entrypoint.sh my…” 11 seconds ago Up 10 seconds 4567-4568/tcp, 0.0.0.0:9001->3306/tcp pn2 172.18.0.3
dfd733cbb49b pxc:5.7 “/entrypoint.sh my…” About a minute ago Up About a minute 4567-4568/tcp, 0.0.0.0:9000->3306/tcp pn1 172.18.0.2

–新增数据库节点操作
–创建数据卷
docker volume create --name v4

docker volume ls //查看数据卷
–新增容器
–要注意的是,这次 CLUSTER_JOIN 连的是 pn3
docker run -di --name=pn4 --net=pxc-network -p 9003:3306 -v v4:/var/lib/mysql --privileged -e MYSQL_ROOT_PASSWORD=123456 -e CLUSTER_NAME=cluster1 -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=pn3 pxc:5.7
–进入数据库
–发现数据已经同步过来了
docker exec -it pn4 /usr/bin/mysql -uroot -p123456

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是创建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集群的步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值