创建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中运行安卓应用程序现在就像在手机上运行应用程序一样简单。微软和亚马逊联手打造了数千款...
你 发表评论:
欢迎- 一周热门
-
-
前端面试:iframe 的优缺点? iframe有那些缺点
-
带斜线的表头制作好了,如何填充内容?这几种方法你更喜欢哪个?
-
漫学笔记之PHP.ini常用的配置信息
-
其实模版网站在开发工作中很重要,推荐几个参考站给大家
-
推荐7个模板代码和其他游戏源码下载的网址
-
[干货] JAVA - JVM - 2 内存两分 [干货]+java+-+jvm+-+2+内存两分吗
-
正在学习使用python搭建自动化测试框架?这个系统包你可能会用到
-
织梦(Dedecms)建站教程 织梦建站详细步骤
-
【开源分享】2024PHP在线客服系统源码(搭建教程+终身使用)
-
2024PHP在线客服系统源码+完全开源 带详细搭建教程
-
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)