大家好!今天这篇文章主要向大家介绍 Sealos 的数据库服务。在 Sealos 上数据库后端服务由 KubeBlocks 提供,为用户的数据库应用保驾护航。无论你是在公有云还是本地环境中使用,Sealos 都能为你管理关系数据库、NoSQL、向量数据库和流数据库等各种类型的数据库。它专为生产环境而设计,提供可靠、高性能、可观测且经济高效的数据基础设施。

让我们来看看数据库应用的魅力吧:

功能介绍

创建数据库

Sealos 提供了一个简单易用的数据库前端应用,屏蔽了繁琐的命令行操作。你只需通过 Database 应用就能轻松创建各种数据库,包括 Mysql、PostgreSQL、MongoDB、Redis 等多种类型的数据库。

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

连接使用

进入详情页面,你可以查看数据库的详细信息,并通过一键连接功能与数据库进行交互。这让操作变得更加便捷,让你与数据库之间的互动更加高效。

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

高可用测试

Sealos 在提供高可用服务方面表现出色,确保在关键时刻数据库能够正常工作,不会出现故障。这为你的数据提供了额外的保障,让你放心使用。我们将通过一个小小的测试来验证数据库的高可用。

首先创建一个实例数大于 1 的数据库应用,这里我们创建一个 3 实例的 PostGreSQL:

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

创建完成后便可通过一键连接功能进入到数据库命令终端:

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

我们点击 Add a Terminal 按钮创建第二个终端应用。

同时我们查看一下当前的主节点是哪个,发现是 test-postgresql-1

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

现在我们要删除这个主节点,通过 kubectl delete pod test-postgresql-1 命令即可进行删除操作:

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

备份恢复功能

我们的数据库还提供了强大的备份恢复功能,这意味着即使出现数据丢失或损坏的情况,你也能轻松恢复到备份时的状态。无论是数据误删,还是面临灾难情况,备份都能帮助你快速恢复数据库,减少业务中断的时间。

下面也通过实例具体测试一下,我提前准备了一些数据用来测试:

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

进入到备份列表点击「备份」按钮进行备份操作:

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

这里我们演示一下手动备份的功能,备份名和备注都可以进行修改,我们直接点击「开始备份」按钮进行备份:

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

备份完成后通过状态可以查看备份的结果:

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

我们可以点击 「恢复」的图标进行恢复功能,并且等待恢复的数据库成功启动:
使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

进入到恢复的数据库中进行数据查看,可以发现数据成功的恢复出来:

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

监控功能

在 Sealos 中,你不仅能轻松管理数据库,还能享受到用户友好的监控功能。你可以随时查看数据库的运行状态,并通过图表和指标监控数据库的性能表现。

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

实现原理

看到这里你可能会好奇 KubeBlocks 为何能在 Sealos 上提供稳定、高效的数据库服务。让我们一起深入了解它的实现原理并了解一下它的高可用架构以及备份恢复策略吧!

有状态服务设计

KubeBlocks 以一种灵活的方式进行数据库拓扑设计。它通过使用复制关系的 Replicated State Machine(RSM)作为核心组件,将复杂的分布式数据库拆分成无缝连接的基础组件(block)。无论是 Stateless、StatefulSet 还是 RSM,都可以轻松应用于 KubeBlocks 中。这意味着,你可以将任何数据库引擎与 KubeBlocks 结合使用,构建出更加灵活的系统架构。

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

高可用架构设计

KubeBlocks 实现了两种高可用算法:quorum-based 和经典主备。对于 quorum-based 类的数据库,KubeBlocks 提供了角色探测、角色校正和重建等功能,而数据库本身则负责更完整的探测、决策和切换等主体功能。对于经典主备场景,如 MySQL 和 PostgreSQL 主备,KubeBlocks 负责执行完整的探测、决策、切换、重建和角色校正等任务。此外,KubeBlocks 还采用通用的高可用架构,支持各种数据库类型,例如复制集群和分片集群,通过增加副本数量来提高可靠性和可用性,降低数据丢失的概率。

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

备份恢复设计

为了进一步保护数据并防止丢失或损坏,KubeBlocks 提供了备份恢复策略。备份可以用于多种情况,例如数据丢失、灾难恢复和数据迁移。在 Sealos 中,我们提供了物理备份功能,这意味着直接复制数据库的物理文件(包括数据文件和日志文件)到备份介质(如磁盘或磁带)上。物理备份具有快速恢复、数据一致性和空间效率的特点。它可以更高效地将备份文件还原到原始数据库,保持与数据库的物理状态完全一致,并且占用较少的存储空间。特别适用于大型数据库的备份和恢复需求,进一步提升 Sealos 作为生产环境的能力。

使用 KubeBlocks 为 K8s 提供稳如老狗的数据库服务-LMLPHP

如果你对数据库服务感兴趣,我强烈推荐你尝试 Sealos 上的数据库服务。无论你是开发者、数据工程师还是系统管理员,这个稳如老狗的数据库服务都能帮助你更高效地管理和运维你的数据。让 Sealos 成为你的得力助手,让你的数据库运行如飞!

08-22 19:35