本文介绍: 1*HDp3_wvu78Vaa-4C9NFHaQ.gif你是否曾听说过避免在Kubernetes运行数据库建议?有人认为Kubernetes不适合有状态应用程序,但这些说法是否属实?让我们深入探讨并挑战这些说法。Kubernetes:有关有状态工作负载的误解平台在涉及有状态应用程序时,Kubernetes经常受到不公平的抨击。这种误解源自早期阶段,当时我们选择局限于部署(Deploymen…
aacfa35f70feb14c7119fde73a1957a5.gif
1*HDp3_wvu78Vaa-4C9NFHaQ.gif

是否曾听说过避免在Kubernetes运行数据库建议?有人认为Kubernetes不适合有状态应用程序,但这些说法是否属实?让我们深入探讨并挑战这些说法

Kubernetes:有关有状态工作负载的误解平台

在涉及有状态应用程序时,Kubernetes经常受到不公平的抨击。这种误解源自早期阶段,当时我们的选择局限于部署(Deployments)和有状态集(StatefulSets)。最初认为有状态集应该数据库的首选。然而,这忽略了Kubernetes的真实本质——一种设计用于定制化的可扩展平台

网络存储是Kubernetes的典型例子。我们并不依赖内置功能,而是通过CNI和CSI插件增强功能适应我们特定的需求。这个原则也适用于数据库,尽管由于缺乏标准数据库接口,这条路并不那么直接。

有状态集的困境

最初,早期采用使用有状态集在Kubernetes上运行数据库。它们提供了一定程度的秩序——可预测扩展性、稳定的网络标识符和持久存储。然而,仅有有状态集是不足以在生产环境管理数据库的,生产环境需要备份故障转移、可观察性等更多功能

自定义资源定义

对于Kubernetes中的数据库来说,真正改变游戏规则的是自定义资源定义(CRDs)和自定义控制器,也称为运算符operators)。这些Kubernetes扩展允许创建具有自定义逻辑生命周期管理复杂有状态应用程序。换句话说,它们赋予了Kubernetes智能、高效地处理数据库的能力。这种方法将Kubernetes的功能扩展到了远远超出核心功能领域,使其能够满足数据库管理复杂需求

使用Cloud Native PG运行PostgreSQL

为了说明问题,让我们探讨一下使用Cloud Native PG项目在Kubernetes上运行PostgreSQL。CloudNativePG的设计允许在多个区域扩展PostgreSQL架构,提供了一个强大的灾难恢复框架,RPO(恢复目标)极小。使用Cloud Native PG,你不仅仅是通过有状态集来管理Pods;你正在利用一个专用控制器,它封装数据库管理的一系列扩展职责。该项目体现了Kubernetes作为基础平台到成为一个完全成熟的运行数据库的强大平台的转变。它支持从高可用设置备份、扩展和配置管理的所有内容,都是通过CRDs进行声明定义

Cloud Native PG的架构

可用性和流复制

核心层,CNPG同时支持异步同步复制。它允许配置一个实例,以及多个备份副本实现同一Kubernetes集群内的高可用性服务可供应用程序连接到主实例**-rw**)、热备份副本(**-ro**)或任何实例进行只读工作负载**-r**)。

共享

CNPG推荐采用共享体系结构以增强韧性。这意味着PostgreSQL实例位于不同的Kubernetes工作节点上,跨越不同的可用区,不共享存储每个节点理想情况下使用本地卷(local volumes存储PostgreSQL数据,从而提高集群的容错性。CNPG自动化更新服务以适应集群拓扑的变化。例如,在故障转移期间,它会更新**-rw**服务,将应用程序流量重定向到新晋升的主实例,确保无缝的连续性。

读写只读工作负载

应用程序可以连接**-rw**服务以在主实例上执行操作。对于只读工作负载应用程序使用**-ro**服务连接到热备份副本,从而分担主节点查询负载。这种设置旨在优化集群中的工作负载分布。

92ab14508ff73ce23b557fe39e39375f.png

1*x1awaxO5sUlYwnenLWYKfQ.png

集群部署和灾难恢复

CNPG通过一个名为副本集群(Replica Cluster)的功能支持多个Kubernetes集群的部署。这种设置涉及在一个集群中拥有一个可写主实例,以及在其他集群中拥有只读副本集群,促进全球性的灾难恢复,并减少RPO(恢复点目标)和RTO(恢复时间目标)。

部署运算

要开始使用CloudNativePG(CNPG),你需要在你的Kubernetes环境中部署运算符。可以通过使用**kubectl**应用一个YAML清单文件来完成。按照以下步骤安装CNPG运算符:

安装所需版本运算清单文件。可以使用以下命令

kubectl apply -f https://raw.githubusercontent.com/cloudnative-pg/cloudnative-pg/release-1.20/releases/cnpg-1.20.4.yaml

•通过检查部署状态来验证安装

kubectl get deploy -n cnpg-system cnpg-controller-manager

默认情况下,运算符作为Kubernetes的**Deployment**安装在**cnpg-system**命名空间中。此部署的名称取决于安装方法

•使用**kubectl**中的**describe**命令获取有关运算符部署的更多详细信息

kubectl describe deploy -n cnpg-system

部署PostgreSQL集群

一旦CNPG运算符安装完成,你可以通过应用定义所需的**Cluster**配置文件来部署PostgreSQL集群。下面是一个示例配置文件(**cluster-example.yaml**),它定义了一个使用默认存储类的简单的3节点PostgreSQL集群:

apiVersion: postgresql.cnpg.io/v1
kind: Cluster
metadata:
  name: cluster-example
spec:
  instances: 3
  primaryUpdateStrategy: unsupervised
  storage:
    size: 1Gi

使用以下命令应用配置文件来创建一个3节点的PostgreSQL集群:

kubectl apply -f cluster-example.yaml

可以使用**get pods**命令检查集群Pods的状态:

kubectl get pods

通过按照这些步骤,你可以在Kubernetes环境快速设置CNPG运算符并部署PostgreSQL集群。为了将你的集群与其他工作负载隔离开来,考虑创建一个单独的命名空间或使用标签识别与特定集群相关对象。运算符将为了便于管理**cnpg.io/cluster**标签应用相关对象

Kubernetes和数据库的未来

Cloud Native PG证明了Kubernetes适合数据库,特别是在增强了CRDs和自定义控制器的情况下。它已经提交给CNCF进行孵化,有望成为生态系统中的PostgreSQL旗舰项目

选择正确的数据库管理路径

关键的决策在于选择托管数据库服务还是自管理方法。在后一种情况下,Kubernetes在如Cloud Native PG这样的解决方案中表现出色,为其采用提供了一个有力的论据。

结论:拥抱Kubernetes的方式

Kubernetes已经成长为运行数据库的最佳平台,前提是我们要接受其可扩展的本质。Cloud Native PG不仅是一个选择;它是PostgreSQL的首选,提供了丰富的功能集和开源社区支持的保证。如果你倾向于自管理数据库,考虑Cloud Native PG——它不是替代方案,而是未来发展的最佳方式


计算机的层次化架构

每个开发者都应该知道的7个原则

6个系统设计的基本概念

数据库:系统设计的核心

系统设计中的缓存技术:完整指南

关系数据库的全景图 

Redis 全景解析

当然架构设计全景图解系列还有很多,快来关注一起学习吧~

原文地址:https://blog.csdn.net/weixin_37604985/article/details/134724965

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_25364.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注