如何创建MySQL的PXC集群

下载PXC集群镜像文件

下载

docker pull percona/percona-xtradb-cluster

重命名

[root@hongshaorou ~]# docker tag docker.io/percona/percona-xtradb-cluster pxc

创建内部网络

处于安全考虑,需要给PXC集群实例创建Docker内部网络

创建网段:

  1.  
    [root@hongshaorou ~]# docker network create --subnet=172.18.0.0/24 net1
  2.  
    ad5c096baebe656f530576344ecde9a3674b907134aced66df27a8d72feefc63

查看网段

  1.  
    [root@hongshaorou ~]# docker network inspect net1
  2.  
    [
  3.  
    {
  4.  
    "Name": "net1",
  5.  
    "Id": "ad5c096baebe656f530576344ecde9a3674b907134aced66df27a8d72feefc63",
  6.  
    "Created": "2018-06-06T10:06:28.55654238+08:00",
  7.  
    "Scope": "local",
  8.  
    "Driver": "bridge",
  9.  
    "EnableIPv6": false,
  10.  
    "IPAM": {
  11.  
    "Driver": "default",
  12.  
    "Options": {},
  13.  
    "Config": [
  14.  
    {
  15.  
    "Subnet": "172.18.0.0/24"
  16.  
    }
  17.  
    ]
  18.  
    },
  19.  
    "Internal": false,
  20.  
    "Attachable": false,
  21.  
    "Containers": {},
  22.  
    "Options": {},
  23.  
    "Labels": {}
  24.  
    }
  25.  
    ]

删除网段

[root@hongshaorou ~]# docker network rm net1

创建Docker卷

Docker容器使用原则:一旦创建出容器,尽量不要在容器中保存数据。一般通过目录映射将数据保存在宿主机里面(我们把宿主机的一个目录映射到容器内,然后容器的数据都保存到映射目录,这样就保存到了宿主机,即使容器损坏,宿主机也有数据保存)。但是,PXC技术在使用Docker的时候无法直接使用映射目录,需要另外一种映射技术—Docker卷。

容器中的PXC节点映射数据目录的解决办法

  1.  
    创建Docker卷:[root@hongshaorou ~]# docker volume create --name v1
  2.  
    --name:设置卷名 可以不写

我们创建的Docker卷是在宿主机上可以看到的具体映射真实目录

  1.  
    [root@hongshaorou ~]# docker inspect v1
  2.  
    [
  3.  
    {
  4.  
    "Driver": "local",
  5.  
    "Labels": {},
  6.  
    "Mountpoint": "/var/lib/docker/volumes/v1/_data",
  7.  
    "Name": "v1",
  8.  
    "Options": {},
  9.  
    "Scope": "local"
  10.  
    }
  11.  
    ]
  12.  
    我们看到Docker卷v1映射到了/var/lib/docker/volumes/v1/_data

删除Docker卷

[root@hongshaorou ~]# docker volume rm v1

创建PXC容器

只需要向PXC镜像传入运行参数就能创建出PXC容器

  1.  
    [root@hongshaorou ~]# docker run -d -p 3307:3306 -v v1:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 --privileged --name=node1 --net=net1 --ip 172.18.0.2 pxc
  2.  
    1da51c2b8817f414ad825ba48f69a46c176f0b5ba7539e3b31e9ac54de056877
  3.  
     
  4.  
    参数解释:
  5.  
    -d:表示后台运行
  6.  
    -v:映射Docker卷到容器的mysql数据目录
  7.  
    MYSQL_ROOT_PASSWORD:表示创建的数据库密码
  8.  
    CLUSTER_NAME: 表示创建出的集群名字
  9.  
    XTRABACKUP_PASSWORD:表示集群通信密码
  10.  
    --privileged:表示分配最高权限
  11.  
    --net:指定网段
  12.  
    --ip:指定IP
  13.  
     
  14.  
    [root@hongshaorou ~]# docker ps -a
  15.  
    CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  16.  
    1da51c2b8817 pxc "/entrypoint.sh " 7 seconds ago Up 5 seconds 4567-4568/tcp, 0.0.0.0:3307->3306/tcp node1

这样我们就创建了第一个PXC节点

下面依次创建剩余四个节点

创建Docker卷

  1.  
    [root@hongshaorou ~]# docker volume create --name v2
  2.  
    v2
  3.  
    [root@hongshaorou ~]# docker volume create --name v3
  4.  
    v3
  5.  
    [root@hongshaorou ~]# docker volume create --name v4
  6.  
    v4
  7.  
    [root@hongshaorou ~]# docker volume create --name v5
  8.  
    v5

创建容器

  1.  
    创建node2:
  2.  
    [root@hongshaorou ~]# docker run -d -p 3308:3306 -v v2:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 --privileged --name=node2 --net=net1 --ip 172.18.0.3 pxc
  3.  
     
  4.  
    创建node3:
  5.  
    [root@hongshaorou ~]# docker run -d -p 3309:3306 -v v3:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 --privileged --name=node3 --net=net1 --ip 172.18.0.4 pxc
  6.  
     
  7.  
    创建node4:
  8.  
    [root@hongshaorou ~]# docker run -d -p 3310:3306 -v v4:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 --privileged --name=node4 --net=net1 --ip 172.18.0.5 pxc
  9.  
     
  10.  
    创建node5:
  11.  
    [root@hongshaorou ~]# docker run -d -p 3311:3306 -v v5:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 --privileged --name=node5 --net=net1 --ip 172.18.0.6 pxc
  12.  
     
  13.  
    查看当前有哪些运行容器:
  14.  
    [root@hongshaorou ~]# docker ps -a
  15.  
    CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  16.  
    f7638daaa09b pxc "/entrypoint.sh " 7 seconds ago Up 4 seconds 4567-4568/tcp, 0.0.0.0:3311->3306/tcp node5
  17.  
    909261673fac pxc "/entrypoint.sh " 25 seconds ago Up 24 seconds 4567-4568/tcp, 0.0.0.0:3310->3306/tcp node4
  18.  
    763dca13edcd pxc "/entrypoint.sh " 43 seconds ago Up 42 seconds 4567-4568/tcp, 0.0.0.0:3309->3306/tcp node3
  19.  
    9a3f92074ad0 pxc "/entrypoint.sh " About a minute ago Up About a minute 4567-4568/tcp, 0.0.0.0:3308->3306/tcp node2
  20.  
    1da51c2b8817 pxc "/entrypoint.sh " 15 minutes ago Up 15 minutes 4567-4568/tcp, 0.0.0.0:3307->3306/tcp node1

在创建剩余容器的时候需要注意的是网络和端口的映射不同,以及多了-e CLUSTER_JOIN=node1 表示加入node1节点。

注意:第一个节点创建时间较长,必须等待两分钟左右再创建剩余节点。

创建好之后我们就可以使用客户端连接数据库

转自:https://zhaobugs.com/2018/06/06/Docker搭建PXC集群

Docker搭建PXC集群的更多相关文章

  1. Docker 搭建pxc集群 + haproxy + keepalived 高可用(二)

    上一节我们有了两个分片的pxc集群,这一节我们接着安装haproxy和keepalived的实现集群的高可用 一.先下载haproxy的镜像 [root@localhost ~]# docker pu ...

  2. Docker 搭建pxc集群 + haproxy + keepalived 高可用(一)

    一.首先需要安装好docker,安装方法可以参考之前一篇博文Centos7安装docker [root@localhost ~]# systemctl start docker [root@local ...

  3. docker安装pxc集群

      前言 现在mysql自建集群方案有多种,keepalived.MHA.PXC.MYSQL主备等,但是目前根据自身情况和条件,选择使用pxc的放来进行搭建,最大的好处就是,多主多备,即主从一体,没有 ...

  4. Docker 搭建 etcd 集群

    阅读目录: 主机安装 集群搭建 API 操作 API 说明和 etcdctl 命令说明 etcd 是 CoreOS 团队发起的一个开源项目(Go 语言,其实很多这类项目都是 Go 语言实现的,只能说很 ...

  5. Docker搭建RabbitMQ集群

    Docker搭建RabbitMQ集群 Docker安装 见官网 RabbitMQ镜像下载及配置 见此博文 集群搭建 首先,我们需要启动运行RabbitMQ docker run -d --hostna ...

  6. docker搭建etcd集群环境

    其实关于集群网上说的方案已经很多了,尤其是官网,只是这里我个人只有一个虚拟机,在开发环境下建议用docker-compose来搭建etcd集群. 1.拉取etcd镜像 docker pull quay ...

  7. docker 搭建zookeeper集群和kafka集群

    docker 搭建zookeeper集群 安装docker-compose容器编排工具 Compose介绍 Docker Compose 是 Docker 官方编排(Orchestration)项目之 ...

  8. 基于docker安装pxc集群

    基于docker安装pxc集群 一.PXC 集群的安装 PXC集群比较特殊,需要安装在 linux 或 Docker 之上.这里使用 Docker进行安装! Docker的镜像仓库中包含了 PXC数据 ...

  9. 使用Docker搭建Spark集群(用于实现网站流量实时分析模块)

    上一篇使用Docker搭建了Hadoop的完全分布式:使用Docker搭建Hadoop集群(伪分布式与完全分布式),本次记录搭建spark集群,使用两者同时来实现之前一直未完成的项目:网站日志流量分析 ...

随机推荐

  1. Spring Boot + Spring Cloud 实现权限管理系统 权限控制(Shiro 注解)

    技术背景 当前,我们基于导航菜单的显示和操作按钮的禁用状态,实现了页面可见性和操作可用性的权限验证,或者叫访问控制.但这仅限于页面的显示和操作,我们的后台接口还是没有进行权限的验证,只要知道了后台的接 ...

  2. Python语言:下载上证股票数据程序

    from urllib.request import urlretrieve f = open('SHA.csv', 'r')for line in f: data = line.split(',') ...

  3. Python编程--类的分析

    一.类的概念 python是面向对象的编程语言,详细来说,我们把一类相同的事物叫做类,其中用相同的属性(其实就是变量描述),里面封装了相同的方法,比如:汽车是一个类,它包括价格.品牌等属性.那么我们如 ...

  4. Redis常用命令与高级应用

    附: 127.0.0.1:6379> set xiaofei 小飞 OK 127.0.0.1:6379> get xiaofei "\xe5\xb0\x8f\xe9\xa3\x9 ...

  5. lombok安装

    今天学习spring boot 时候发现的lombok挺好用的,我这个使用的是spring boot 管理的版本,如果其他的可能需要你们自己去添加版本了,开发工具使用的是idea. maven: &l ...

  6. js封装选项卡

    <div class="forestcamp_box"> <img src="img/home_02.jpg" /> <div c ...

  7. day04元组

    元组 1.元祖书写规范 users=[11,22,33,"老男孩"]#列表(可变) users=(11,22,33,"老纳海")#元祖(不可变) 1.公共方法( ...

  8. c——二分查找

    思路: 1.输入:数组长度n,待查找的有序数组a[],要找的元素key 2.输出:待查找元素在数组中的位置,若不存在返回-1 3.实现:三个指针,left.mid.right #include< ...

  9. 再见了我热爱的ACM赛场

    随着2017EC-Final结束,我的ACM生涯也真正结束了,区域赛三铜三银三金,没有打铁,对我来说算是很满足了. 为什么打了ACM?我记得进入大学之后大概认真上课两三周,我就开始对大学讲课失望,开始 ...

  10. openstack--9--深入理解虚拟机

    登录计算节点查看进程 [root@linux-node2 ~]# ps aux | grep kvm root 824 0.0 0.0 0 0 ? S< 10:19 0:00 [kvm-irqf ...