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

本文探讨了如何将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 中国区独家战略合作伙伴卓普云官网,卓普云会为中国区的用户提供商务合作、技术支持等服务。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Coze+Discord:打造你的免费AI助手(教您如何免费使用GPT-4o/Gemini等最新最强的大模型/Discord如何正确连接Coze)

文章目录 📖 介绍 📖🏡 演示环境 🏡📒 文章内容 📒📝 准备Discord📝 准备Coze🔌 连接💡 测试效果⚓️ 相关链接 ⚓️📖 介绍 📖 你是否想免费使用GPT-4o/Gemini等最新最强的大模型,但又不想花费高昂的费用?本文将教你如何通过Coze搭建Bot,并将其转发…

计算机网络(2) 网络层:IP服务模型

一.Internet Protocol在TCP/IP四层模型中的作用 第三层网络层负责数据包从哪里来到哪里去的问题。传输层的数据段提交给网络层后,网络层负责添加IP段,包含数据包源地址与目的地址。将添加IP段的数据包交由数据链路层添加链路头形成最终在各节点传输中所需…

YASKAWA机器人HW1171921-B电缆维修

安川机器人作为现代工业自动化的重要设备,其稳定运行对于生产线的连续性和效率至关重要。然而,随着使用时间的增长,可能会出现各种YASKAWA机器人本体线缆故障,如断线、短路、接触不良等。 一、安川工业机器人电缆维修前的准备 在进…

Java | Leetcode Java题解之第147题对链表进行插入排序

题目: 题解: class Solution {public ListNode insertionSortList(ListNode head) {if (head null) {return head;}ListNode dummyHead new ListNode(0);dummyHead.next head;ListNode lastSorted head, curr head.next;while (curr ! null) {if (…

糖尿病患者血糖控制困难,4个辅助降糖方法分享。

对于糖尿病患者来讲,血糖控制极为困难,稍不留意就会致使忽高忽低的情况出现,今天我来教你 4 个办法来辅助降糖。 第一,在饮食上可多进食全谷类食物,中医认为谷类食物是脾胃的主食。经常吃这类食物不但能够给脾胃提供充…

流媒体传输协议HTTP-FLV、WebSocket-FLV、HTTP-TS 和 WebSocket-WS的详细介绍、应用场景及对比

一、前言 HTTP-FLV、WS-FLV、HTTP-TS 和 WS-TS 是针对 FLV 和 TS 格式视频流的不同传输方式。它们通过不同的协议实现视频流的传输,以满足不同的应用场景和需求。接下来我们对这些流媒体传输协议进行剖析。 二、传输协议 1、HTTP-FLV 介绍:基于 HTTP…

word怎么单页横向设置(页码不连续版)

打开word,将光标放在第一页的最后位置。 然后点击布局下的分隔符,选择下一页。 将光标放在第二页的开头,点击布局下的纸张方向,选择横向即可。 效果展示。 PS:如果那一页夹在两页中间,那么在…

Github 2024-06-13 Go开源项目日报Top10

根据Github Trendings的统计,今日(2024-06-13统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Go项目10TypeScript项目1Shell项目1多存储文件列表/WebDAV程序 创建周期:1265 天开发语言:Go协议类型:GNU Affero General Public License v…

TIA博途Wincc与S7-1500 (V2.9) 或S7-1200 (V4.5) 及更高版本固件PLC通信失败的原因汇总

TIA博途Wincc与S7-1500 (V2.9) 或S7-1200 (V4.5) 及更高版本固件PLC通信失败的原因汇总 从TIA Portal V17开始,对于S7-1500PLC新增了V2.9的固件,S7-1200新增了V4.5的固件,PLC侧默认激活了“仅支持PG/PC和HMI的安全通信”, 注意事项1 如果PLC侧激活了“仅支持PG/PC和HMI的安…

Golang | Leetcode Golang题解之第148题排序链表

题目&#xff1a; 题解&#xff1a; func merge(head1, head2 *ListNode) *ListNode {dummyHead : &ListNode{}temp, temp1, temp2 : dummyHead, head1, head2for temp1 ! nil && temp2 ! nil {if temp1.Val < temp2.Val {temp.Next temp1temp1 temp1.Next} …

opencv_特征检测和描述

理解特征 寻找独特的特定模式或特定特征&#xff0c;可以轻松跟踪和比较。 拼图&#xff1a;在图像中搜索这些特征&#xff0c;找到它们&#xff0c;在其他图像中查找相同的特征并对齐它们。而已。 基本上&#xff0c;角被认为是图像中的好特征。 在本单元中&#xff0c;我…

graalvm编译springboot3 native应用

云原生时代容器先行&#xff0c;为了更好的拥抱云原生&#xff0c;spring boot3之后&#xff0c;推出了graalvm编译boot项目&#xff0c;利用jvm的AOT&#xff08; Ahead Of Time &#xff09;运行前编译技术&#xff0c;可以将javay源码直接构建成机器码二进制的文件&#xff…

光伏项目管理——数字化改革

随着全球对可再生能源的迫切需求以及环保意识的日益增强&#xff0c;光伏产业作为清洁能源的重要组成部分&#xff0c;正迎来快速发展的黄金时期。然而&#xff0c;传统的光伏项目管理方式已逐渐无法满足现代化、高效化的需求&#xff0c;数字化改革成为了行业发展的必然趋势。…

如何在Excel中快速找出含有多位小数的数字

在日常工作中&#xff0c;使用Excel处理数据是一项常见任务。然而&#xff0c;有时我们会遇到一些看似简单&#xff0c;却令人头疼的问题。例如&#xff0c;当我们在一个包含大量数据的列中发现某个数字的小数点位数过多时&#xff0c;如何快速找到这个数字&#xff1f;本文将介…

.net8 blazor auto模式很爽(二)用.net8创建Blazor自动模式项目

在vs2022中创建新项目&#xff0c;在搜索框里输入blazor&#xff0c;选择blazor web app 在其他信息里框架选.net8&#xff0c;模式选择auto,点创建。 我们可以看到&#xff0c;vs自动创建了两个项目。一个叫BlazorApp1&#xff0c;另外一个叫BlazorApp1.Client。没有Client就…

网络地图的发展历程

位置以及我们与位置的互动方式已在我们的生活中无处不在。我们的网络地图技术发展到今天这一步&#xff0c;涉及一系列个人、公司和想法&#xff0c;这些最终塑造了我们与世界的互动方式。这篇文章能帮助您了解我们是如何一步步走到今天的。即网络地图的发展历史! 制图学的简要…

如何思考生成式人工智能著作权案件中的救济问题

如何思考生成式人工智能著作权案件中的救济问题 迄今为止&#xff0c;在16起指控OpenAI和其他生成人工智能(AI)技术开发商侵犯版权的诉讼中&#xff0c;最引人注目的指控是&#xff0c;为了训练生成人工智能模型而复制受版权保护的作品侵犯了版权。 一些评论员相信&#xff0c…

明星百科大全PHP网站源码

源码介绍 明星百科大全网站源码&#xff0c;国内外明星娱乐音乐、新闻八卦、写真照片、相关影视作品等等的明星百科网站源码。 源码截图 源码下载 明星百科大全PHP网站源码

【全开源】餐饮点餐小程序源码(ThinkPHP+FastAdmin+Uniapp)

&#x1f37d;️餐饮点餐小程序&#xff1a;让美食触手可及 一款基于ThinkPHPFastAdminUniapp开发的点餐小程序&#xff0c;支持单人点餐&#xff0c;还满足多人协同点餐(高级授权)&#xff0c;支持多门店管理&#xff0c;并提供先吃后付和先付后吃两种支付方式。​ &#x1…

ArcGIS Pro 3.0加载在线高德地图

1、打开ArcGIS Online官网&#xff0c;登录自己的账号&#xff0c;登录后效果如下图所示 官网地址&#xff1a;https://www.arcgis.com/home/webmap/viewer.html 2、点击Add&#xff0c;选择Add Layer from Web&#xff0c;如下图所示 3、在显示的Add Layer from Web页面内&am…