美文网首页运维
docker 中部署mysql PXC集群

docker 中部署mysql PXC集群

作者: 沙砾丶ye | 来源:发表于2020-04-19 20:58 被阅读0次

    docker的安装:

    使用aliyun docker yum源安装新版docker
    删除已安装的Docker

    [root@yixuan ~]# yum remove docker \
    docker-client \
    docker-client-latest \
    docker-common \
    docker-latest \
    docker-latest-logrotate \
    docker-logrotate \
    docker-selinux \
    docker-engine-selinux \
    docker-engine
    

    配置阿里云Docker Yum源

    yum install -y yum-utils device-mapper-persistent-data lvm2 git
    yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    

    安装并启动docker

    yum install -y docker-ce
    systemctl start docker
    docker info    #查看docker版本状态
    docker version   #查看docker运行状态
    

    搭建PXC 集群

    与 MySQL 不同的是 PXC 官方提供了 Docker 镜像,所以我们可以很方便的搭建 PXC 集群

    1. 下载docker镜像

    docker pull percona/percona-xtradb-cluster:5.7
    

    2.重命名镜像名称

    docker tag percona/percona-xtradb-cluster:5.7 pxc:5.7docker tag percona/percona-xtradb-cluster:5.7 pxc:5.7
    

    3.删除原始镜像

    docker rmi percona/percona-xtradb-cluster:5.7
    

    4.创建 Docker 网络,用于 PXC 集群独立使用

    docker network create pxc-network
    

    5.创建数据卷用于之后挂载

    docker volume create --name v1
    docker volume create --name v2
    docker volume create --name v3
    

    6.创建第一个节点

    docker run -di --name=pxc1 --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 查看日志,如果出现下面的输出,证明启动成功:

    2019-09-04T06:27:30.085880Z 0 [Note] InnoDB: Buffer pool(s) load completed at 190904  6:27:30
    

    7.添加第二个节点

    docker run -di --name=pxc2 --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=pxc1 pxc:5.7 
    

    需要注意是第二个节点开始需要增加 e CLUSTER_JOIN=pxc1 参数,表示与 pxc1 节点同步,否则 pxc1 容器会自动关闭。
    当 PXC集群中存在两个节点以上之后就没有主节点的概念了。集群中最后一个退出的节点就会变为主节点,在/var/lib/mysql/grastate.dat 文件中属性 safe_to_bootstrap 的值 会从 0 被设置为 1 表示该节点是主节点。

    8.添加第三个节点

    docker run -di --name=pxc3 --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=pxc2 pxc:5.7  
    

    可以看到我们这次我们 CLUSTER_JOIN 的是 pn2 容器,可以证明我们刚刚说的 当 PXC 集群存在两个节点以上之后就没有主节点.

    9.进入 pxc 节点中任意 一个节点中

    mysql -uroot -p123456 -h 192.168.0.4 -P9000
    mysql -uroot -p123456 -h 192.168.0.4 -P9001
    mysql -uroot -p123456 -h 192.168.0.4 -P9002
    

    查看集群的状态

    show status like 'wsrep%';
    

    显示三个节点都连接成功


    image.png

    集群同步测试
    1.再节点一创建数据库(test)

    mysql> create database test;
    Query OK, 1 row affected (0.02 sec)
    

    2、再另外两个节点查看

    mysql> show databases;
    +--------------------+
    | Database           |
    +--------------------+
    | information_schema |
    | mysql              |
    | performance_schema |
    | sys                |
    | test               |
    +--------------------+
    5 rows in set (0.00 sec)
    

    新增数据库节点的操作
    1.创建数据卷

    docker volume create --name v4
    

    2.新增容器

    docker run -di --name=pxc4 --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=pxc3 pxc:5.7 
    

    宕机操作

    1.把节点pn4容器关闭,造成宕机现象

    docker stop pxc4
    

    2.再其他节点上做查看集群状态

    mysql> show status like 'wsrep%';
    

    可以看到集群应该有4个节点,但是现在只有3个正常连接。
    在进行修改数据的操作,然后在在重新启动的pxc4,你会发现,pxc4 也会将修改后的数据同步。

    相关文章

      网友评论

        本文标题:docker 中部署mysql PXC集群

        本文链接:https://www.haomeiwen.com/subject/cvxibhtx.html