MySQL 高可用基础教程之二高可用架构方案介绍
大纲
概述
高可用架构方案分类
高可用方案 | 保证数据强一致性 | 使用说明 | 描述 |
---|---|---|---|
主从复制 | 否 | 支持单主 | 只适用于对可用性和数据一致性要求较低的业务场景。 |
MMM | 否 | 支持单主 | 基本淘汰了,在一致性和高并发稳定性等方面有些问题。 |
MHA | 否 | 支持单主 | 有少数开发者还在用,但也有些问题,也是趋于淘汰的 MySQL 主从高可用方案。 |
MGR | 是 | 支持单主 / 多主 | 基于 MySQL 官方从 5.7.17 版本开始引入的组复制技术。 |
MySQL Cluster | 是 | 支持多主 | MySQL 官方提供的一种分布式数据库解决方案,只支持 NDB 引擎。 |
Galera Cluster | 是 | 支持多主 | 引领时代的主从复制高可用技术。 |
Galera Cluster for MySQL | 是 | 支持多主 | MySQL 对 Galera Cluster 的实现。 |
MariaDB Galera Cluster (MGC) | 是 | 支持多主 | MariaDB 对 Galera Cluster 的实现。 |
Percona XtraDB Cluster (PXC) | 是 | 支持多主 | Percona 对 Galera Cluster 的实现,目前业界使用 PXC 的会多一些。 |
MySQL InnoDB Cluster | 是 | 支持单主 / 多主 | MySQL 官方推出的一套完整高可用性解决方案。 |
MySQL 事件调度器的使用
SpringBoot 3 进阶教程之二 GraalVM 与 AOT
大纲
- SpringBoot 3 进阶教程之一整合 Prometheus 与 Grafana
- SpringBoot 3 进阶教程之二 GraalVM 与 AOT
- SpringBoot 3 进阶教程之三整合 Spring Security
- SpringBoot 3 进阶教程之四自定义 Starter
前言
本文主要介绍 SpringBoot 3 如何使用 AOT 技术,包括在 Windows、Linux 平台使用 GraalVM 将 SpringBoot 应用编译成原生镜像(二进制可执行文件)。
AOT 与 JIT
AOT
:Ahead of Time(提前编译),程序执行前,全部被编译成机器码JIT
:Just in Time(即时编译),程序边编译边运行
编译器与解释器
编程语言的分类
- 编译型语言:依赖编译器 (Complier),如 C、C++
- 解释型语言:依赖解释器 (Interpreter),如 JavaScrpt、Python
SpringBoot 3 进阶教程之一整合 Prometheus 与 Grafana
大纲
- SpringBoot 3 进阶教程之一整合 Prometheus 与 Grafana
- SpringBoot 3 进阶教程之二 GraalVM 与 AOT
- SpringBoot 3 进阶教程之三整合 Spring Security
- SpringBoot 3 进阶教程之四自定义 Starter
前言
本文主要介绍 SpringBoot 3 如何整合 Actuator、Prometheus 与 Grafana,实现微服务应用的监控。
官方文档
概念介绍
可观测性
可观测性 (Observability) 一般是指对线上应用进行观测、监控、预警等,包括的详细内容如下:
- 健康状况:组件状态、存活状态等,属于 Health 范畴
- 运行指标:CPU、内存、垃圾回收、吞吐量、响应成功率等,属于 Metrics 范畴
- 链路追踪
- ……
Docker 快速搭建 SpringBoot 3 开发环境
Debian 安装 MySQL 5.7 教程
令牌桶和漏桶限流算法的 Java 实现
Spring 之 @Async 与线程池的使用
SpringBoot3 基础教程之一快速入门
大纲
- SpringBoot3 基础教程之一快速入门
- SpringBoot3 基础教程之二常规配置
- SpringBoot3 基础教程之三 Web 开发
- SpringBoot3 基础教程之四 Web 开发
- SpringBoot3 基础教程之五基础特性
- SpringBoot3 基础教程之六场景整合
- SpringBoot3 基础教程之七场景整合
- SpringBoot3 基础教程之八场景整合
- SpringBoot3 基础教程之九核心原理
开发环境要求
环境 & 工具 | 版本 |
---|---|
SpringBoot | 3.0.5+ |
IDEA | 2021.2.1+ |
JDK | 17+ |
Maven | 3.5+ |
Tomcat | 10.0+ |
Servlet | 5.0+ |
GraalVM Community | 22.3+ |
Native Build Tools | 0.9.19+ |