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

Docker实战之Mysql集群搭建 docker部署mysql集群

yuyutoo 2024-11-08 15:39 2 浏览 0 评论

Mysql集群常见的集群方式有两种,第一种是主备模式(一主多备或多主多备);另外一种是Cluster模式,这里介绍Percona XtraDB Cluster(简称PXC-Mysql)搭建方式。

PXC-Mysql介绍

Pxc-mysql是针对mysql开源的高可用解决方案,集群由多个节点组成,其中每个节点都包含相同的数据集。建议的配置是至少有3个节点,但也可以有2个节点。每个节点都是一个MySQL服务器实例。

Pxc-Mysql集群搭建

准备三台服务器,这里采用docker方式安装,mysql版本是8.022,大家可根据使用自行选择版本

1、创建目录

$ mkdir -m 777 -p /pxc-mysql/data
$ mkdir -m 777 -p /pxc-mysql/cert
$ mkdir -m 777 -p /pxc-mysql/config

2、在config目录中创建cert.cnf

$ touch cert.cnf
$ vi cert.cnf

把以下内容复制到cert.cnf中

[mysqld]
lower_case_table_names=1
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
ssl-ca = /cert/ca.pem
ssl-cert = /cert/server-cert.pem
ssl-key = /cert/server-key.pem

[client]
ssl-ca = /cert/ca.pem
ssl-cert = /cert/client-cert.pem
ssl-key = /cert/client-key.pem

[sst]
encrypt = 4
ssl-ca = /cert/ca.pem
ssl-cert = /cert/server-cert.pem
ssl-key = /cert/server-key.pem

3、在主节点创建ssl证书,介绍两种方式

a. 自动创建ssl证书

$ docker run --name pxc-cert --rm -v /pxc-mysql/cert:/cert percona/percona-xtradb-cluster:8.0.22 mysql_ssl_rsa_setup -d /cert

b. 手动生成秘钥和证书

(1) 创建ca证书,首先要确保系统已安装openssl

#创建CA证书
$ cd /cert 
$ openssl genrsa 2048 > ca-key.pem
Generating RSA private key, 2048 bit long modulus (2 primes)
....................................+++++
..+++++
e is 65537 (0x010001)

$ openssl req -new -x509 -nodes -days 3600 \
 -key ca-key.pem -out ca.pem

Can't load /root/.rnd into RNG
140331426972096:error:2406F079:random number generator:RAND_load_file:Cannot open file:../crypto/rand/randfile.c:88:Filename=/root/.rnd
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:CN
State or Province Name (full name) [Some-State]:SH
Locality Name (eg, city) []:
Organization Name (eg, company) [Internet Widgits Pty Ltd]:whu
Organizational Unit Name (eg, section) []:
Common Name (e.g. server FQDN or YOUR name) []:
Email Address []:

创建CA的时候需要填一些信息,可根据情况自行填写

(2) 创建服务器证书

#创建服务器证书
# server-cert.pem = 公钥, server-key.pem = 私钥
$ openssl req -newkey rsa:2048 -days 3600 \
 -nodes -keyout server-key.pem -out server-req.pem
 
Ignoring -days; not generating a certificate
Can't load /root/.rnd into RNG
140086461567424:error:2406F079:random number generator:RAND_load_file:Cannot open file:../crypto/rand/randfile.c:88:Filename=/root/.rnd
Generating a RSA private key
............................................................................................................................+++++
......................+++++
writing new private key to 'server-key.pem'
-----
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:CN
State or Province Name (full name) [Some-State]:SH
Locality Name (eg, city) []:
Organization Name (eg, company) [Internet Widgits Pty Ltd]:whu #作者随意写的
Organizational Unit Name (eg, section) []:
Common Name (e.g. server FQDN or YOUR name) []:
Email Address []:
Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []:
An optional company name []:

 $ openssl rsa -in client-key.pem -out client-key.pem
$ openssl x509 -req -in client-req.pem -days 3600 \
 -CA ca.pem -CAkey ca-key.pem -set_serial 01 -out client-cert.pem

注意:创建server证书的时候,需要填一些信息,可根据情况自行填写,填写的信息必须与创建CA时填写的一致

(3) 证书验证

$ openssl verify -CAfile ca.pem server-cert.pem client-cert.pem
#如果显示以下内容表示一切么问题
server-cert.pem: OK
client-cert.pem: OK

4、创建overlay类型网络,可选

好处是mysql服务都在一个专属的网络ip段。当然也可不创建,通过服务器ip进行访问

$ docker network create -d overlay --attachable --subnet=173.30.0.0/16 microservice-net

5、把上面创建的证书复制到其它节点机器相同位置

6、在各节点服务器分别创建percona-xtradb-cluster,mysql密码自行替换

node1:

docker run -d \
-p 3306:3306 \
-e MYSQL_ROOT_PASSWORD=<自行填写密码> \
-e CLUSTER_NAME=PXC \
-e XTRABACKUP_PASSWORD=<自行填写密码> \
-e "TZ=Asia/Shanghai" \
-v /pxc-mysql/data:/var/lib/mysql \
-v /pxc-mysql/cert:/cert \
-v /pxc-mysql/config:/etc/percona-xtradb-cluster.conf.d \
--privileged \
--name=node1 \
--net=microservice-net --ip 173.30.1.11 \
percona/percona-xtradb-cluster:8.0.22

node2:

docker run -d \
-p 3306:3306 \
-e MYSQL_ROOT_PASSWORD=<自行填写密码> \
-e CLUSTER_NAME=PXC \
-e XTRABACKUP_PASSWORD=<自行填写密码> \
-e "TZ=Asia/Shanghai" \
-e CLUSTER_JOIN=node1 \
-v /pxc-mysql/data:/var/lib/mysql \
-v /pxc-mysql/cert:/cert \
-v /pxc-mysql/config:/etc/percona-xtradb-cluster.conf.d \
--privileged \
--name=node2 \
--net=microservice-net --ip 173.30.1.12 \
percona/percona-xtradb-cluster:8.0.22

node3

docker run -d \
-p 3306:3306 \
-e MYSQL_ROOT_PASSWORD=<自行填写密码> \
-e CLUSTER_NAME=PXC \
-e XTRABACKUP_PASSWORD=<自行填写密码> \
-e "TZ=Asia/Shanghai" \
-e CLUSTER_JOIN=node1 \
-v /pxc-mysql/data:/var/lib/mysql \
-v /pxc-mysql/cert:/cert \
-v /pxc-mysql/config:/etc/percona-xtradb-cluster.conf.d \
--privileged \
--name=node3 \
--net=microservice-net --ip 173.30.1.13 \
percona/percona-xtradb-cluster:8.0.22

7、验证

$ docker exec -it node1 /usr/bin/mysql -uroot -p<密码>

注意:其中一个节点断开,无法重启,修改grastate.dat中的safe_to_bootstrap: 0改为1

$ cd /pxc-mysql/data
$ vi grastate.dat
safe_to_bootstrap: 1

注意:node2和node3节点需等node1创建成功后再创建,否则会导致无法加入集群。另外,集群需要同步服务器时钟,如果购买的是云服务器,则不需要同步,供应商已为我们做了同步

至此,mysql三节点集群已创建,可连接任何一台mysql写入数据,其它节点数据库均能实时同步数据

更多实战部署会陆续推出,请关注

相关推荐

史上最全的浏览器兼容性问题和解决方案

微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...

平面设计基础知识_平面设计基础知识实验收获与总结
平面设计基础知识_平面设计基础知识实验收获与总结

CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...

2025-02-21 16:01 yuyutoo

写作排版简单三步就行-工具篇_作文排版模板

和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

写一个2048的游戏_2048小游戏功能实现

1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...

今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……

  最近的天气暖和得让很多小伙伴们喊“热”!!!  昨天的气温到底升得有多高呢?你家有没有榜上有名?...

CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式

之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...

柠檬科技肖勃飞:大数据风控助力信用社会建设

...

你的自我界限够强大吗?_你的自我界限够强大吗英文

我的结果:A、该设立新的界限...

行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?

行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...

让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华

去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...

2025-02-21 16:00 yuyutoo

今年国家综合性消防救援队伍计划招录消防员15000名

记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...

一起盘点最新 Chrome v133 的5大主流特性 ?

1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...

竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使

style="text-align:center;"data-mce-style="text-align:...

学物理能做什么?_学物理能做什么 卢昌海

作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...

你不知道的关于这只眯眼兔的6个小秘密
你不知道的关于这只眯眼兔的6个小秘密

在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...

2025-02-21 16:00 yuyutoo

取消回复欢迎 发表评论: