百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

创建MySQL集群 建立mysql

yuyutoo 2024-11-08 15:40 3 浏览 0 评论

PXC镜像安装

pxc集群比较特殊,只能安装在 Linux 系统之上,既可以在 linux 系统之上直接安装,也可以在 docker 上安装,这里选择的是后者,Docker的镜像仓库中包含了PXC数据库的镜像,下载即可。

https://hub.docker.com/r/percona/percona-xtradb-cluster/


在网页的右侧可以看到安装镜像的指令,这个指令执行之后,docker就会把镜像下载到docker虚拟机里面并安装

docker pull percona/percona-xtradb-cluster

或者

docker pull percona/percona-xtradb-cluster:5.7.21

另外一个方式就是本地安装,前提是本地存储了pxc镜像压缩文件,可以通过下面方式将镜像导入到docker虚拟机里面。其实安装的pxc镜像我们也可以通过保存到本地压缩文件,这样就可以拷贝到其他电脑上,如果想安装pxc镜像,直接就可以导入。

docker load < /home/soft/pxc.tar.gz

执行 docker images 指令


可能觉得名字很长,可以修改下名字

docker tag docker.io/percona/percona-xtradb-cluster pxc

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


再次执行下 docker images 指令,我们发现多了一个pxc的镜像


现在我们可以把原先的镜像删除掉,然后再去查看一下镜像,发现没有了

docker rmi docker.io/percona/percona-xtradb-cluster

docker rmi percona/percona-xtradb-cluster:5.7.21

创建内部网络

出于安全考虑,需要给PXC集群实例创建Docker内部网络。上面安装的PXC镜像创建的容器就是PXC集群内部的数据库实例。

假如我们要搭建一个有5节点的集群,就要创建出5个PXC容器,创建出来的PXC容器不要直接对接Docker以外的网络,那样很不安全。出于安全考虑,我们需要先给PXC集群在docker虚拟机内部单独划分一个网段,这个网段外部是无法直接访问的,然后向外部开放什么端口,我们可以使用docker端口映射技术去实现。

指令

docker network create net1

创建名为 net1 的网段,这个网段的IP是什么样的呢?docker虚拟机自带的网段是 172.17.0.*,这是它内置的网段,如果我们创建的网段是 net1 ,那么我们的网址就是 172.18.0.*,如果再去创建第二个的网段,那么IP就是 172.19.0.*,如果我想创建的网段不是 172.18.*.*,我们也可以自己规定。

  • 如果我创建的网段是 net1 ,我想查看网段的相关信息,可以执行下面指令

docker network inspect net1

  • 删除网段

docker network rm net1

实操

docker network create --subnet=172.18.0.0/24 net1

    • 参数是 --subnet=,表示自己指定网段
    • 自己指定的具体网段是 172.18.0.0
    • 子网掩码是24位的
    • 网段名字为net1

出现下面信息表示该网段已成功创建

查看网段信息,其中的Subnet就是网段的具体IP

docker inspect net1

如果将来要删除网段

docker network rm net1

创建Docker卷

docker容器使用原则,一旦创建出docker容器,我们尽量不要在容器里面保存业务数据,要把业务数据保存到宿主机里面,使用的技术就是目录映射,把宿主机中的一个目录映射到容器内,运行容器的时候把业务数据保存到映射目录里面,也就是存储到了宿主机里面,这样如果出现什么故障的的话,宿主机有这个数据,我只需要把故障的容器删除掉,重新启动一个新的容器,然后把目录映射给新的容器,那么新的容器启动就自带了这些业务数据。

PXC运行在docker容器里面,它是无法直接使用映射的目录,也就是说我们如果采用映射目录的技术直接给PXC容器,PXC容器启动的时候会闪退,那我们就需要使用另外一种映射的技术,这个技术叫做 Docker卷

实操

  • 创建数据卷 v1

docker volume create --name v1

docker数据卷名字是通过 --name 参数来指定的,比如卷的名字叫 v1 ,有时 --name 也可以不写,直接 docker volume create v1

我们创建的docker卷在宿主机上也是可以看得见的,它是在宿主机上的docker创建一个卷,这个卷在宿主机上是可以看到目录的,然后把这个卷映射给容器,这样我们PXC容器启动,就可以把数据映射到卷的目录里面,我们通过宿主机也可以看到映射的数据。


上面是创建数据卷,提示数据卷 v1 已成功创建,下面是查看数据卷创建到什么位置


从上面的信息可以看到数据卷在宿主机上真实的路径是 /var/lib/docker/volumes/v1/_data ,那么我们可以在将来创建PXC容器的时候将数据卷 v1 映射到容器的MySQL目录里面,如果我们想要删除这个数据卷也是可以的,使用下面指令

docker volume rm v1

创建PXC容器

指令

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

在docker虚拟机上创建容器使用指令 docker run ,那么创建PXC容器也是 docker run,但是需要向指令传入一些特定的参数才能创建出我们想要的PXC容器

docker run -d -p 3306: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

    • -d: 创建出来的容器在后台去运行;
    • -p: 端口的映射,前面的端口是宿主机的端口,后面的端口是容器的端口,就是把容器的3306端口映射到宿主机的3306端口上;
    • -v: 路径的映射,之前我们创建了数据卷,v1就是我们刚才创建的数据卷,v1:/var/lib/mysql 表示v1数据卷映射MYSQL的数据目录,容器中的数据库目录是 /var/lib/mysql
    • -e MYSQL_ROOT_PASSWORD=abc123456: 启动参数,表示创建出来的数据库实例对应的密码是什么,用户名就是root,我们改不了;
    • -e CLUSTER_NAME=PXC: 表示创建出来的PXC集群的名字,名字可以自己去规定;
    • -e XTRABACKUP_PASSWORD=abc123456: 表示数据库节点之间同步用到的密码;
    • –privileged: 表示给到的最高权限;
    • –name=node1: 给创建出来的容器起的名字,这里器的名字为node1;
    • –net=net1: 表示使用的内部网段是net1;
    • –ip 172.18.0.2: 容器分到的ip;
    • pxc: 镜像的名字;

执行上面的指令,那么一个pxc的容器就成功创建出来了,这里我先不创建,我先创建数据卷 v2, v3, v4, v5

docker volume create v2

docker volume create v3

docker volume create v4

docker volume create v5



  • 创建pxc容器

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


容器的创建非常快,但是容器里面MySQL数据库的初始化并不是一瞬间就会完成的,MySQL数据库的初始化至少需要两分钟以上,数据库实例的初始化时比较耗时的,如果第一个PXC容器里的MySQL没有启动成功,我就创建了第二个PXC的容器,那么第二个PXC容器启动之后会闪退,因为第二容器的MySQL会和第一个容器里面的MySQL做同步的时候,它会发现第一个容器里面的MySQL没有成功启动,那么它就会出现一些故障导致第二个PXC容器闪退,所以需要耐心等待第一个容器里MYSQL成功初始化,并且通过客户端能成功连接到MySQL实例了,再去创建第二个,第三个第四个第五个PXC实例。

我们打开Navicat客户端,创建一个MySQL连接,连接到第一个节点上名字为DB1,IP为宿主机的IP,端口是宿主机的端口,因为5个节点映射了5个端口是3306,用户名root

出现下面表示连接成功。


上面操作成功后我们就可以创建第二个、第三个、第四个、第五个PXC节点的容器了

下面创建第二个PXC容器节点

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

注意只有第一个容器里的数据库实例初始化比较慢,其他的相对会比较快一点。

现在去创建第三个,第四个,第五个

docker run -d -p 3308:3306 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 -v v3:/var/lib/mysql --privileged --name=node3 --net=net1 --ip 172.18.0.4 pxc

docker run -d -p 3309:3306 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 -v v4:/var/lib/mysql --privileged --name=node4 --net=net1 --ip 172.18.0.5 pxc

docker run -d -p 3310:3306 -e MYSQL_ROOT_PASSWORD=abc123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=abc123456 -e CLUSTER_JOIN=node1 -v v5:/var/lib/mysql --privileged --name=node5 --net=net1 --ip 172.18.0.6 pxc


这样5个PXC容器就都启动成功了,可以通过客户端连接一下容器里面的MYSQL


我们在 DB1 中创建一个 test 的数据库


我们看一下其他节点


我们在 DB1 节点的 test 库中创建一个数据表,表名为 student 学生表,并往表中插入一条数据


提交之后我们看一下其他的节点

节点2:


节点3:


节点4:


节点5:


现在我在节点5中再插入一条数据,看一下是否会同步到其他节点


节点1:


节点2:


节点3:


节点4:

相关推荐

URL URI傻傻分不清楚,dart告诉你该怎么用

简介如果我们要访问一个网站,需要知道这个网站的地址,网站的地址一般被称为URL,他的全称是UniformResourceLocator。那么什么是URI呢?...

你最深爱的编程语言其实很烂

我最近写了几篇比较严肃的博客,是关于一些沮丧的事情,结果我开始有些忧郁。很严重。所以,我想应该说些比较轻松的事情。我要做的就是数落大家最喜欢的编程语言。你会问我为什么,为什么要搞这种恶作剧?亲爱的朋友...

路由器交换机基础配置6——命令行显示信息设置

一、控制命令行显示信息设备中的部分命令执行后会出现提示、警告、执行结果等显示信息,用户可以控制这些显示信息的显示方式,以方便阅读。1、提示和警告信息提供中、英文两种语言显示。可以通过language-...

python是一种什么类型的编程语言

Python(英国发音:/'paθn/美国发音:/'paθɑn/)是一种广泛使用的解释型、高级编程、通用型编程语言,由吉多·范罗苏姆创造,第一版发布于1991年。可以视之为一种改良(加入一些其他编程...

60年了,LISP语言的进化史是否会引发你对AI未来的新思考?

图:pixabay作为长期垄断AI领域的高级计算机语言程序,Lisp语言到底经过了怎样的变迁?也许,我们可能已经忘记了一些在今天仍然有用的东西,或者说,至少了解这些历史对一些新的想法产生有所影响。o2...

Java 和 JavaScript 的关系

Java和JavaScript不同之处:●出身不同:Javascript与Java是由不同的公司开发的不同产品。Javascript是Netscape公司的脚本语言,而Java...

Micro:命令行文本编辑器 (Go)

Micro是一款基于终端的文本编辑器,使用Go开发。Micro是个命令行编辑器,主要特性是易用,直观,并且包含所有现代化终端的优点。功能:易用常用快捷键绑定(ctrl-s,ctrl-c,...

7 行代码 3 分钟:从零开始实现一门编程语言

本文最初发布于MattMight的个人博客。...

码上去学海南公司:C语言到底能干什么?我列举了8种经典案例

虽然C语言执行速度极快,占用资源极少,但是它使用起来非常麻烦,完全没有Java、Python、Go、JavaScript、C#等方便和灵活,会严重拖慢项目的开发进度,所以,通常只有在“不得不”的情...

什么是 JavaScript?

本文首发自「慕课网」,想了解更多IT干货内容,程序员圈内热闻,欢迎关注!作者|慕课网精英讲师然冬...

新人如何自学安卓手机软件开发?

当我们问一个人,你是做什么的,听到我是做软件开发的,不由自主就会感觉,这个人好厉害。越来越多的人投身于软件开发行业,可能有些人本身不是学这个专业的,出于对这个行业的热爱,自学软件开发。现在这个社会,多...

Android开发基础入门(一):UI与基础控件

Android基础入门前言:...

第02章 《小Z安卓程序员之路》Android Studio

不积跬步无以至千里,不积小流无以成江海!!每天进步一点点我是杨哲丶,一个梦想把科技和艺术结合在一起的程序猿!!小Z在开始查询的如何使用SVN和如何使用Git版本控制工具的时候,发现网上大部分居然是关于...

支付宝团队 | 移动客户端实战教程(iOS和Android)

今天给大家推荐一个非常好的PPT,是github在线的,是支付宝团队内部分享技术用的PPT,适合Web端和移动端的同学入门客户端开发,是我见过的最详细的《iOS&Android开发从入门到...

只需二步,就可以在win11操作系统上运行Android程序,非常简单

你想像过吗,只需几个简单的步骤即可在你的Windows电脑上运行Android应用程序。现在,在Windows11中运行安卓应用程序现在就像在手机上运行应用程序一样简单。微软和亚马逊联手打造了数千款...

取消回复欢迎 发表评论: