云原生笔记6

一、Mysql 实验

(一)Mysql 源码编译

1.下载安装包

可以直接去浏览器官网下载好压缩包,上传到虚拟机:

2.源码编译

3.部署

4.数据结构初始化

可以看到默认数据库的 root 用户密码:

5.启动

6.安全初始化

增加两台主机(node2 和 node3):

node2:

node3

测试:

(二)主从架构

1.编写 my.cnf 主配置文件

node1:

node2:

node3:

在三台主机中重启数据库:

2.建立同步时需要用到的数据库账号

node1:

node2:

3.配置数据库一主一从

在 master 中查看日志文件名称及 id:

在 slave 主机中:

数据同步成功,及日志回访成功:

4.测试

在 master 中建立库:

在 slave 主机中可以实现数据同步:

5.加入新的数据库到当前一主一从

模拟一主一从中已经存在数据情况:

加入新从库时需要手动拉平数据:

6.将新库加入主从结构中

在 master 中查看日志的 id:

node3:

7.测试一主两从

在 master 中建立数据:

在新加入的 slave 中(node3)查看信息:

(三)主从架构中的使用技巧及优化

1.延迟复制

在指定需要延迟同步的 slave 主机中(node2):

在 master 主机中对数据进行更改:

在未被延迟的 slave 数据库中查看是否数据操作动作被同步(node3):

在被设定延迟复制的主机中查看动作是否被同步(60秒内库不变),延迟时间过后再次查看,库已经同步了。

2.慢查询日志

查看慢查询日志是否开启:

开启慢查询日志:

检测慢查询日志(慢查询阈值):

不会生成慢查询日志:

3.gtid 模式

在 master 和 slave中 默认 gtid 模式是未开启的:

在三台主机中新增参数,并全部重启:

在三台主机中分别查看 gtid 模式是否开启:

在从库中停止 slave 功能:

4.多线程回放

在 slave 主机中,默认回访日志时使用单线程回放:

开启多线程回放日志:

查看更改生效信息:

5.半同步模式

在 master 主机中操作:

在 slave 主机中(node2 和 node3):

测试(在主库中):

模拟 ack 故障 在所有 slave 主机中(把两台从机的 IO_THREAD 都关掉后,有等待ack时间):

在主库写入数据:

恢复故障 在所有 slave 主机中

(四)MHA 高可用集群环境配置

1.准备工作-保证数据一致性

重新初始化数据(先关掉 mysql 服务):

重新配置主从,在剩下的 slave 主机中:

2.在所有主机中安装 Mha 相应软件

实现免密登录:

新增一台主机(MHA),配置:

验证组建是否安装成功:

在 mha 节点:

3.在 slave 中安装相应软件

4.修改 MHA-Manager 中的检测代码

5.为 MHA 建立远程登录用户

6.生成 MHA-manager 的配置文件模板

7.修改配置文件

8.检测环境

9.在 slave 中安装 mha-node 软件依赖

在所有的数据库主机中安装依赖:

后续和 MHA 的配置一样,如下载失败,可改为使用 http 。最后重新进入 cpan 下载即可:

验证是否成功:

(五)集群切换操作

1.手动切换

(1)master 无故障切换

默认状态:

执行切换,把 master 切换到 node2:

(2)故障后切换

查看切换信息:

当出现故障切换后,mha 主机中会出现切换锁文件,文件存在后不能再次执行切换:

2.自动切换

为了方便观察建议开启两个 shell:

(六)还原 mysql 所有节点

1.利用 ansible 还原

2.手动还原

(七)部署组复制

设置所有 mysql 节点的解析:

配置组复制-在首台主机中:

配置组复制在其余主机中:

测试(所有节点是否可以执行读写并数据是否同步):

node1

node2

node3

(八)Mysqlrouter

1.软件下载

2.安装

3.配置文件

4.部署

5.测试

在 mysq l节点的任意主机中添加 root 远程登录:

相关推荐
JAVA社区9 小时前
Java高级全套教程(十一)—— Kubernetes 超详细企业级实战详解
java·运维·微服务·容器·面试·kubernetes
暴躁小师兄数据学院9 小时前
【AI大数据工程师特训笔记】第14讲:Linux操作系统与shell脚本
大数据·人工智能·笔记
茫忙然10 小时前
U 盘搭建免驱 Linux 便携系统教程
linux·服务器
土狗TuGou10 小时前
SQL内功笔记 · 第8篇:事务的四大特性与隔离级别
数据库·笔记·后端·sql·mysql·oracle
流星白龙10 小时前
【MySQL高阶】10.MySQL架构,连接层服务层
mysql
智者知已应修善业10 小时前
【51单片机用T0定时器方式1,实现0.5S的时间间隔实现第一次一个灯亮、第二次二个灯亮,直到全部灯亮,然后重复整个过程】2023-12-29
c++·经验分享·笔记·算法·51单片机
木头程序员11 小时前
SSM框架学习笔记
java·开发语言·mysql·spring·maven
一起逃去看海吧11 小时前
dify-03
java·linux·开发语言
fengyehongWorld11 小时前
Linux 根据端口进行的相关查询
linux
lihao lihao11 小时前
linux匿名管道
linux·运维·服务器