Kubernetes 基础架构最佳实践:从架构设计到平台自动化

news2024/11/27 8:46:52

本文探讨了如何将DigitalOcean Kubernetes (DOKS)应用于生产环境,并提供实现生产准备(production readiness)的指导。

规划您的基础架构

Kubernetes 基础架构的规划至关重要,因为它为稳定且可扩展的应用部署平台奠定了基础。通过适当的规划,您可以避免性能问题、安全漏洞和其他可能影响应用程序可用性的问题。

合适的地区

选择合适的地区对应用程序的性能和体验有重大影响,并确保符合当地法规。在部署工作负载之前,企业必须考虑一些基本因素,例如与最终用户的距离、监管要求、网络延迟、多个数据中心的位置以及改进的冗余和崩坏恢复能力。

例如,我们新推出的最先进的 SYD1 数据中心具有以下优势:

  • 专用的互联网边缘和骨干网络,可以直接接入亚洲、北美和欧洲,减少对公共互联网的依赖。
  • SYD1 的网络吞吐量/容量高达 400 Gbps,并通过当今最低的延迟链路与加利福尼亚州和新加坡相连。
  • 这使其成为在 DigitalOcean Kubernetes 上运行网络密集型工作负载的理想场所。

想要了解更多详情,请参阅《如何为您的企业选择数据中心位置》指南,其中提供了可以帮助你做出决定的建议。

联网策略

VPC(虚拟私有云)是 DigitalOcean 资源的逻辑隔离。通过将资源隔离到公共互联网无法到达的网络中,VPC 网络可以更好地保护执行环境、租户和应用程序的安全。

在 DigitalOcean Kubernetes 中,VPC 为你的 Kubernetes 集群创建了一个私有网络,你还可以轻松地在同一个 VPC 中配置其他 DigitalOcean 资源,如托管数据库集群。这有助于保护 Kubernetes 工作负载免受未经授权的访问。例如,你可以在同一 VPC 中创建一个或多个 DOKS 集群,以建立安全的 Kubernetes 工作负载及其集群间通信。

一个重要的建议是仔细规划 VPC 架构,考虑特定使用案例的安全和连接需求。你还需要通过在 VPC 网络内创建租户来提高网络隔离度。

更多信息,请查阅:

  • 《如何规划自定义 VPC 网络》
  • 《VPC 网络:最佳实践》

Kubernetes 基础架构设计

集群架构

一个常见的要求是,Kubernetes 集群既能扩展以适应不断增加的工作负载,又能在出现故障(如数据中心中断、机器故障、网络分区)时保持容错能力和可用性。因此,在设计集群架构(控制平面和节点平面)之前,必须考虑这些因素。幸运的是,作为 Kubernetes 托管服务提供商,我们为用户分担了建立高弹性、高可用性控制平面的所有负担,用户只需将更多精力放在节点平面架构设计上。

DigitalOcean HA 控制平面架构

集群控制平面

虽然集群只需一个控制平面节点就能完全正常运行,但在集群升级或底层基础设施中断期间,Kubernetes API 可能无法使用,从而导致服务停机。

我们强烈建议为生产工作负载启用 DigitalOcean 的高可用性(HA)控制平面。

如需进一步了解,请查阅《Kubernetes 高可用性控制平面如何最大限度地延长正常运行时间并提供可靠性》,其中讨论了为生产工作负载提供 HA 控制平面的重要性。

节点平面架构

在确定集群中节点的规格,例如 CPU、内存和存储资源之后,考虑到预期的工作负载、可扩展性要求以及特定的硬件或软件依赖性。你可能无法在第一次就做到完美,这可能需要几个周期才能达到理想状态。DigitalOcean Kubernetes 还提供集群自动调节器(Cluster Autoscaler, CA),可根据集群调度 pod 的能力自动添加或删除节点,从而调整 Kubernetes 集群的规模。

当您需要在 Kubernetes 集群中写入和访问持久化数据时,您可以创建并访问 DigitalOcean 块存储 。这时需要创建一个 PersistentVolumeClaim(PVC)作为部署的一部分。DigitalOcean 块存储 向 pod 提供一次读写(RWO)块存储。对于多次读写(RWM)块存储或基于文件的存储,可以考虑使用 OpenEBS NFS Provisioner,这是我们 Kubernetes Marketplace 中的一键式应用程序。

有关选择合适节点配置的更多见解,请查阅:

  • 《选择正确的 Kubernetes 计划》
  • 《工作节点大小》

使用 GitOps 实现平台自动化

基础架构自动化有多种方法,但现代最佳实践是围绕 GitOps 演进而来的。GitOps 使用 Git 仓库作为唯一的真相源。与团队使用应用程序源代码的方式类似,采用 GitOps 的运维团队也将配置文件作为代码(基础架构即代码)存储在 Git 仓库中。

基础架构即代码

基础架构即代码(IaC)应成为你管理云基础设施的策略,使你能够利用 GitOps 实现自动化。首先,必须使用代码定义云基础设施的理想状态。这将定义各种基础设施组件和配置,例如 Kubernetes 节点组、存储账户、网络等。

我们不会在此深入探讨 IaC 的重要性,但如果你感兴趣,可以查看《基础架构即代码解释》。

基础架构即代码工具

Terraform、Pulumi 和 Crossplane 等基础设施即代码(IaC)工具使企业能够使用代码管理和配置基础设施。这些工具能自动部署和管理资源,减少人工操作,确保不同环境的一致性。

以下是 DigitalOcean 官方支持的 IaC 软件包:

  • Terraform DigitalOcean
  • Pulumi DigitalOcean
  • Crossplane DigtialOcean

如果你是初学者,需要进一步了解 Terraform 等 IaC 工具,我们建议你按照本系列教程进行操作。

合并请求(MR)

GitOps 使用合并请求(MR)或拉取请求(PR)作为所有基础设施更新的变更机制。在 MR 或 PR 中,团队可以通过审核和评论进行协作,并进行正式批准。合并提交到主(或主干)分支,作为审计日志或审计跟踪。

CI/CD

GitOps 利用带有持续集成和持续交付(CI/CD)功能的 Git 工作流程自动更新基础设施。合并新代码时,CI/CD 管道会在环境中实施变更。任何配置漂移(如手动更改或错误)都会被 GitOps 自动化覆盖,从而使环境趋同于 Git 中定义的理想状态。

以下是 GitOps 最佳实践指南的一些示例:

  • 《设置 CI/CD 实践教程》
  • 《使用 Terraform 和 Flux CD 的 GitOps》

安全与测试

在未来几周,我们将推出一篇专门介绍 Kubernetes 安全最佳实践的文章。

  • 我们建议使用 aquasecurity/kube-bench 通过运行 CIS Kubernetes Benchmark 中记录的检查来确保 Kubernetes 已安全部署。
  • 可以将 aquasecurity/kube-bench 工具纳入 CI 工作流程,也可以单独运行(不推荐)。
  • 此外,你还可以使用 kitchen-terraform 和 terratest 等测试框架来验证使用 Terraform 配置的基础架构。

DigitalOcean Kubernetes IaC 示例

我们整理了一些示例,供你测试并从中汲取灵感。如果你发现错误或希望改进现有示例,请随时在 GitHub 上提出问题。我们一直在不断改进我们的内容。

  • K8s-bootstrapper 是一个可扩展的框架,用于建立由 Terraform 和 ArgoCD 驱动的可投入生产的 DigitalOcean Kubernetes 集群。
  • 在 DOKS 上运行生产工作负载的真实案例:在本项目中,我们将指导你在 DigitalOcean Kubernetes 上安装 Mastodon。你将亲身体验 GitOps 和生产准备的所有现代最佳实践,并与我们的托管 DBaaS 和兼容 S3 的云对象存储 Spaces无缝集成。

最后的思考

  • 为 Kubernetes 建立生产级云基础设施需要周密的规划和设计。
  • 规划基础设施与建设基础设施同样重要。第一次可能会出错,但可以改进,并随着需求的增长而不断发展。
  • 花时间与工程师和架构师讨论网络基础架构。不要重新建造架构,将繁重的工作留给托管的 Kubernetes 服务,如 DigitalOcean Kubernetes,它具有内置的弹性和高可用性。
  • IaC 应该是管理云基础设施的唯一策略。
  • 采用 GitOps 等现代最佳实践实现平台自动化,如本指南所述。
  • 从我们为你整理的真实案例中汲取灵感。
  • 强调安全性(更多内容请参见下一篇博客)。

最后,如果你希望了解更多关于 DigitalOcean Kubernetes 的产品信息,可以访问 DigitalOcean 中国区独家战略合作伙伴卓普云官网,卓普云会为中国区的用户提供商务合作、技术支持等服务。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1803014.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python采集东方财富网股票数据建立LSTM模型预测

Python采集东方财富网股票数据建立LSTM模型预测 一、数据爬取流程二、爬虫完整代码三、LSTM模型建模预测3.1 项目背景3.2 建模预测流程3.3 数据预处理3.4 数据可视化3.5 特征工程3.6 数据缩放3.7 数据转换3.8 模型创建3.9 评价模型3.10 可视化结果3.11 总结一、数据爬取流程 先…

107.网络游戏逆向分析与漏洞攻防-装备系统数据分析-装备信息更新的处理

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 如果看不懂、不知道现在做的什么,那就跟着做完看效果 现在的代码都是依据数据包来写的,如果看不懂代码,就说明没看懂数据包…

实战 | 通过微调SegFormer改进车道检测效果(数据集 + 源码)

背景介绍 SegFormer:实例分割在自动驾驶汽车技术的快速发展中发挥了关键作用。对于任何在道路上行驶的车辆来说,车道检测都是必不可少的。车道是道路上的标记,有助于区分道路上可行驶区域和不可行驶区域。车道检测算法有很多种,每…

【Unity3D小功能】Unity3D中UGUI-Text实现打字机效果

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址QQ群:398291828 大家好,我是佛系工程师☆恬静的小魔龙☆,不定时更新Unity开发技巧,觉得有用记得一键三连哦。 一、前言 需求要实现Text的打字机效果,一看居然…

实战 | YOLOv10 自定义数据集训练实现车牌检测 (数据集+训练+预测 保姆级教程)

导读 本文主要介绍如何使用YOLOv10在自定义数据集训练实现车牌检测 (数据集训练预测 保姆级教程)。 YOLOv10简介 YOLOv10是清华大学研究人员在Ultralytics Python包的基础上,引入了一种新的实时目标检测方法,解决了YOLO以前版本在后处理和模型架构方面…

挂上了代理加速器梯子之后,Git clone指令下载仍旧很慢的问题

当你使用了各种代理软件访问诸如Github、Google、油管、推特这些网址,你会发现基本可以访问,只不过是访问速度不同,但是不管你使用什么代理软件,你的git clone指令从Github远程库下载库的速度都不会受到影响。 当使用代理软件访问…

LIP模型动力学方程例子

线性倒立摆(Linear Inverted Pendulum, LIP)模型是用于描述和控制人形机器人步态的重要工具。LIP模型假设质心沿着一条固定的直线运动,并且所有质量集中在质心上。这简化了计算,使得模型更容易用于控制和稳定分析。 LIP模型动力学方程 LIP模型的基本假设是: 机器人的质心…

【原创】海为PLC与RS-WS-ETH-6传感器的MUDBUS_TCP通讯

点击“蓝字”关注我们吧 一、关于RS-WS-ETH-6传感器的准备工作 要完成MODBUS_TCP通讯,我们必须要知道设备的IP地址如何分配,只有PLC和设备的IP在同一网段上,才能建立通讯。然后还要选择TCP的工作模式,来建立设备端和PC端的端口号。接下来了解设备的报文格式,方便之后发送…

如何有效释放Docker占用的存储空间

随着Docker的广泛应用,我们经常会遇到Docker占用过多存储空间的问题。这可能是由于频繁的镜像拉取、容器创建和删除等操作导致的。本文将介绍几种方法来有效释放Docker占用的存储空间,特别是docker system prune命令的使用。 Docker的存储机制 Docker使…

浔川python社官方警告——浔川总社部、浔川社团举报中心

昨天,浔川社团举报中心接到举报,说有被侵权文章。 今天,小编再搜索“怎么加入浔川python社”时 ,看到了假冒浔川python社的网站。 该网站我社团并不认识,并且侵权了我社 《用python做的一个登录界面——浔川python社》…

海思SS928(SD3403)部署YOLOv5-YOLOv7步骤详解

1. YOLO模型资料 本文档内容以yolov5-7.0工程、yolov5s模型为例。 a. 模型结构 详细的模型结构可以利用netron工具打开.pt或.onnx模型查看。 b. 模型参数即验证结果 其中,YOLOv5n、YOLOv5s、YOLOv5m、YOLOv5l、YOLOv5x为五种类型的预训练模型,其包含的检测类别相…

vue element 接口返回数据与控制台打印数据不一致 踩坑

问题描述: 接口返回数据正常,,控制台打印不对,element el-switch表格中使用,控制台打印数据被改变 如下正常数据 数据id 17状态是0 控制台打印状态却是1 造成原因: element el-seitch组件修改了状态 修…

【Vue】声明式导航-导航链接

文章目录 一、引入二、解决方案三、代码示例四、声明式导航-两个类名1)router-link-active2)router-link-exact-active 一、引入 但凡说到声明式导航,都需要想到router-link 需求 实现导航高亮效果 如果使用a标签进行跳转的话,需要…

TensorFlow2.x基础与mnist手写数字识别示例

文章目录 Github官网文档Playground安装声明张量常量变量 张量计算张量数据类型转换张量数据维度转换ReLU 函数Softmax 函数卷积神经网络训练模型测试模型数据集保存目录显示每层网络的结果 TensorFlow 是一个开源的深度学习框架,由 Google Brain 团队开发和维护。它…

【学术小白成长之路】01三方演化博弈(基于复制动态方程) -基础概念与模型构建

1.演化博弈基础知识 经典博弈论起源于1944年Von Neumann和Morgenstern合著的《博弈论与经济学行为》,是研究理性决策者之间竞争和合作关系的数学方法。 博弈论主要研究完全理性的博弈个体为实现利益最大化而做的策略选择,在过去几十年取得了极大发展&am…

Camtasia Studio怎么自动加字幕呢,Camtasia Studio有什么功能呢

在信息化高度发达的今天,视频作为一种直观、生动的信息表达方式,受到了越来越多人的青睐。无论是教育领域的教学视频,还是企业宣传的推广短片,甚至是个人创作的分享作品,都离不开一款优秀的视频编辑软件。Camtasia Stu…

番外篇 | 利用华为2023最新Gold-YOLO中的Gatherand-Distribute对特征融合模块进行改进

前言:Hello大家好,我是小哥谈。论文提出一种改进的信息融合机制Gather-and-Distribute (GD) ,通过全局融合多层特征并将全局信息注入高层,以提高YOLO系列模型的信息融合能力和检测性能。通过引入MAE-style预训练方法,进一步提高模型的准确性。🌈 目录 🚀1.论文解…

全志D1s软件入门之Tina Linux烧写教程

烧写 Tina Linux 烧写,即将编译打包好的固件下载到设备 烧写方式简介 全志平台为开发者提供了多种多样的烧写方式和烧写工具: (1) PhoenixSuit:基于Windows的系统的烧写工具,是最常用的烧写工具&#x…

【三十三】springboot+序列化实现返回值脱敏和返回值字符串时间格式化问题

互相交流入口地址 整体目录: 【一】springboot整合swagger 【二】springboot整合自定义swagger 【三】springboot整合token 【四】springboot整合mybatis-plus 【五】springboot整合mybatis-plus 【六】springboot整合redis 【七】springboot整合AOP实现日志操作 【…

解决VIvado编程中遇到的bug 5

解决VIvado编程中遇到的bug 5 语言 :Verilg HDL EDA工具: Vivado、quartus2 、modelsim 解决VIvado编程中遇到的bug 5一、引言二、问题、分析及解决方法1. vivado编译时报错(1)错误(2)分析(3&am…