首页 > 其他分享 >掌控基础设施,加速 DevOps 之旅:IaC 深度解析

掌控基础设施,加速 DevOps 之旅:IaC 深度解析

时间:2024-04-22 09:55:51浏览次数:26  
标签:基础设施 之旅 代码 DevOps IaC VCS 使用 工具

在当今的 DevOps 世界中,基础设施即代码(IaC)是一个非常重要的概念。它在整个行业几乎无处不在,是现代工程角色的绝对关键。

 

本文将主要包含 IaC 的定义和它的好处,同时将 Walrus 作为最佳实践来进行详细讲解。

 

什么是基础设施即代码(IaC)

用最简单的话来说,就是使用代码定义需要在描述性模型中部署的基础设施。与应用程序的代码类似,基础设施的代码会成为项目的一部分,并存储在版本控制系统(或 VCS)中

 

例如,您开发了一个网络应用程序。该网络应用程序需要托管在某个基础设施上才能被使用。使用 IaC,您可以定义基础设施的部署地点,如 Microsoft Azure、Amazon AWS 或 Google Cloud 等公有云提供商,以及网络应用程序运行的服务类型,如 Azure 网络应用程序或 AWS S3 存储账户。除此以外,您还可以定义网络应用程序所需的设置,其中可能包括需要多少服务器计算能力(CPU 和内存)、如何确保网络安全以及如何公开应用程序的域名等。

 

基础设施即代码的优势

IaC 解决了基础设施配置中的许多常见问题。其中包括:

 

  • 可通过 IaC 配置代码轻松配置新环境或基础设施。使用 IaC 部署基础设施具有可重复性
  • 手动配置的环境难以衡量。使用 IaC 配置的环境可以快速部署和衡量
  • 如果要对使用 IaC 部署的现有基础设施进行更改,可以在代码中完成,而且更改将被跟踪。
  • 当 IaC 与声明式工具(它描述了您希望环境呈现的状态)一起使用时,您可以检测并纠正环境漂移。如果在代码之外手动修改了基础设施的某个部分,下一次运行时就能使其恢复到所需的状态。
  • 更改可以多次应用,而不会改变初始应用之外的结果。这就是所谓的幂等性
  • 避免手动配置环境,因为人为失误通常会导致错误。有了 IaC,这些错误都可以避免。
  • IaC 是实现跨环境和基础设施一致性的一种手段。代码可以重复使用。
  • 由于部署时间以及管理、管理和维护环境的工作量减少,基础设施成本也随之降低。
  • IaC 可用于持续集成/持续部署(CI/CD)流水线。这样做的主要好处是实现基础设施部署自动化
  • DevOps 团队可以在开发周期的早期在类似生产环境中测试应用程序。
  • 基础设施配置代码与应用源代码一起保存在版本控制系统中,通常在同一个版本库中。现在,一切都可以放在一起。
  • 由于综合了使用 IaC 的所有优点,生产率将会提高
  • 由于代码保存在版本控制系统中,因此可以获得 VCS 的所有优点。

 

IaC 的挑战和局限性

采用 IaC 有许多优势,但同样要考虑其挑战和局限性。通常情况下,企业内的传统基础设施或运维团队可能不熟悉版本控制系统和 Git 的使用,也不擅长使用 Visual Studio code 等代码编辑工具。

 

此外,在企业内部采用新技术肯定会存在学习曲线。这需要培训,也需要时间来培养相应的技能。IaC 和 DevOps 方面的技能目前在业内非常抢手,因此可能很难招聘到具备这些技能的员工。

 

在使用 IaC 管理环境的过程中,通常会先在所选的云平台上部署少量新资源,然后随着企业内部采用 IaC 的情况增多,更多的基础设施就可以开始用代码进行部署和管理。最终,当您的组织成熟并熟悉所选 IaC 系统和工具的原理和操作时,就可以将现有资源置于 IaC 控制之下

 

为什么要将 IaC 存储在版本控制系统(VCS)中?

将基础设施即代码存储在 VCS 中会自动为您带来一系列额外的好处。

 

因为 VCS 使开发人员和组织能够更高效地提高产品质量,同时记录和评估其改进的详细历史记录,从而获得成功的最终产品。简而言之,使用 VCS 可以实现治理、版本管理并加强协作

 

  • 效率:由于配置文件是随变化逐步修改的,因此测试变得更加容易,因为可以回滚到以前的版本。新功能可随着时间的推移而不断增加。
  • 跟踪和版本控制:跟踪谁做了修改,以及在哪个版本的文件中做了修改。可在每次代码修改(或提交)时添加注释。
  • 合作:使用分支功能,多人可同时处理配置文件。可使用 PR 将更改合并在一起。
  • 治理与合规:自动跟踪更改可为您提供强大的审计线索,从而实现风险管理。
  • 管理:通过了解配置的作者、更改所需的时间、时间轴及其影响,可以对管理进行全面了解。
  • 减少重复:减少重复和过时的配置文件。
  • 备份:用户通常会克隆其配置代码所在的资源库,并在本地对其进行处理。这样,代码就同时存在于本地和 VCS 中。VCS 本身也会被备份。

 

声明式方法与命令式方法

编写 IaC 配置文件时使用的模板有两种,不同的工具使用不同的方法。

 

声明式:您定义最终解决方案的理想状态

工具或自动化平台决定如何实现目标,一步步执行由工具处理,不对用户公开。声明式工具是 IaC 领域最流行、最主要的工具。当需要对解决方案进行更改或更新时,它们最为有用

 

声明性工具是幂等的,因为您正在定义解决方案所需的状态。 幂等性让一个进程可以执行多次且结果相同

 

命令式:您定义为达到所需的解决方案而必执行的步骤

命令式方法允许你建立多层命令来达到最终目标。命令式工具可以让你对如何实现目标有更多的控制。这些工具在您需要部署而将来不需要更新或更改解决方案时最为有用。

 

强制方法可能不会导致惰性,最终目标可能因起点不同而产生差异,因为一系列步骤构成了流程。例如,考虑一个有 10 个步骤的流程,从第 1 步开始和从第 6 步开始会导致不同的结果。

 

基础设施即代码工具

相对全面地了解完 IaC 的优势和命令方式,接下来需要决定使用哪个 IaC 工具,这将取决于许多因素,包括您的工程能力和当前对云平台的使用。

 

Walrus 是一款基于 IaC 的开源应用平台,支持 Terraform、OpenTofu 等 IaC 工具。Walrus 采用独特的双层抽象架构,包括 IaC 模板(例如 Terraform 模块)和资源定义(Resource Definition)。IaC 模板允许运维人员创建可复用的基础设施配置,避免重复工作。开发人员则可以通过自助服务的方式进行资源配置和部署,无需深入了解底层技术细节,专注于应用程序开发。资源定义功能赋予运维人员制定和执行企业策略的能力。

 

他们可以定义云资源的使用规则、配置标准和访问权限,确保云资源的使用符合安全合规要求。同时,Walrus 遵循 DRY (Don't Repeat Yourself) 原则,保证跨平台和云环境的一致性,避免代码冗余。

 

此外,Walrus 可以编排整套应用系统,并提供统一的视图简化资源和环境管理。具体而言:

 

  • 应用统一编排:以应用为中心,对应用服务集周边资源依赖(数据库、中间件、负载均衡、网络等)进行统一编排部署。并自动生成依赖图,直观展示底层模块、运行状态及依赖关系等。
  • 动态环境管理:支持灵活的环境配置及管理,支持一键创建、克隆、停止整个应用环境或单个服务,满足各类环境管理需求。
  • 统一视图:Walrus 在单一资源视图中提供针对资源详情各类操作的支持,如查看资源列表、管理资源及其底层组件,查看日志、进行终端调试故障、获取服务的URL等。用户无需切换界面即可完成资源管理。

 

总结

使用 IaC 实现基础设施自动化可以带来红利,使您的团队能够交付更多产品,更加灵活,从而节省时间和金钱。

 

为您的团队选择正确的 IaC 工具可能是一项艰巨的任务,因为有很多选择。比较每种工具的优缺点,同时评估您的需求和团队中可用的技能组合,应该能为您提供一个良好的起点。

 

如果您刚刚开始使用 IaC,建议您优先考虑 Walrus,因为它是当今业界非常抢手的技能,也是最普遍的 IaC 工具。网上有很多学习资料,社区支持也非常好。

标签:基础设施,之旅,代码,DevOps,IaC,VCS,使用,工具
From: https://www.cnblogs.com/sealio/p/18150042

相关文章

  • gRPC入门学习之旅(七)
    gRPC入门学习之旅(一)gRPC入门学习之旅(二)gRPC入门学习之旅(三)gRPC入门学习之旅(四)gRPC入门学习之旅(五)gRPC入门学习之旅(六)3.6、创建gRPC的桌面应用客户端 1.在VisualStudio2022菜单栏上选择“文件—》新建—》项目”。或者在VisualStudio2022的解决方......
  • 开启智慧游园新篇章:公园设施3D可视化的魅力之旅
    在数字化浪潮席卷全球的今天,我们的生活正在经历一场前所未有的变革。从智能家居到无人驾驶,从在线购物到虚拟现实,科技的力量正在不断刷新我们对世界的认知。而今,这一变革的触角已经延伸到了我们休闲娱乐的场所——公园。 想象一下,你站在公园的入口处,通过手机或专门的AR设备,就能......
  • 京东内部研效架构师训练营,首次对外公开课,不可错过的研效之旅!
    五月繁花似锦,让我们带你走进京东,开启研效实战之旅! 四大单位联合发起本次活动由“全国云计算技术行业产教融合共同体”发起,联合工业和信息化部电子第五研究所、E³CI软件研发效能度量工作委员会、京东云共同主办,重磅推出“卓越研效架构师”研习营,邀请30名企业研发核心管理者......
  • Kano的编程之旅
    瓦力觉启|主程序原理---避障|目录一.雷达避障(1)(2)二.深度避障1.原理2.控制3.主要函数(1).雷达避障主函数(2).相关参数三.超声波避障今日份美图一.雷达避障(1)(2)二.深度避障1.原理(1)摄像头的中心与摄像头坐标系统的中心可能存在偏差(2)摄像头的坐标系和小车的坐标......
  • 迈向人工智能LLM的新征程:我的2023年转行之旅
    随着2023年的日历即将翻到最后一页,我迎来了人生中的一个重要转折点——转行进入人工智能LLM领域。这是一个充满挑战和机遇的新征程,我满怀期待地踏上了这片未知而又充满可能性的土地。大型语言模型(LLM)作为人工智能的重要分支,近年来取得了令人瞩目的进展。它们在自然语言处理、文本......
  • IaC:实现持续交付和 DevOps 自动化的关键
    基础架构即代码(IaC)和CI/CD流水线最初似乎并不匹配。因为它们代表了两种不同的流程。IaC主要关注基础设施的配置和开发,而CI/CD则围绕软件开发、测试和部署。 然而,将IaC集成到CI/CD流水线中具有多种优势。首先,它可以将新资源调配到部署流程中。此外,一旦资源使用完毕,就能......
  • 揭秘2024年DevOps顶级工具
    DevOps工具对于作为价值流的基本要素的透明度、自动化和合作起着决定性作用。这些工具对于建立一个高效的信息和技术知识分享及交换渠道至关重要,涵盖了包括开发、运维、安全和商业团队在内的所有相关方。这种合作方式确保了沟通和知识能够顺畅流动,极大地促进了产品交付流程的效......
  • 重启React Native老项目的奇幻之旅:填坑实录与解决方案分享
    这两天为了重启五年前基于ReactNative(版本0.59.9)开发的老项目,经过各种填坑查询等操作,最终把它成功地运行起来了。在这篇文章中,我将详述那些遭遇的挑战以及对应的解决方案,以期为同样面临此类困境的开发者提供宝贵的经验参考。这个项目涉及到的环境基本版本信息如下:react:16.......
  • 探秘研发基地:3D可视化技术的魅力之旅
    在科技日新月异的今天,我们生活在一个充满无限可能性的时代。而在这个时代中,3D可视化技术正以其独特的魅力,引领着科技领域的新一轮变革。 3D可视化技术通过三维图像的方式,将现实世界或虚拟世界中的物体、场景等以立体、逼真的形式呈现出来。在研发基地中,3D可视化技术的应用更是......
  • gRPC入门学习之旅(六)
    gRPC入门学习之旅(一)gRPC入门学习之旅(二)gRPC入门学习之旅(三)gRPC入门学习之旅(四)gRPC入门学习之旅(五) 3.3、客户端编译生成GRPC类1.在“解决方案资源管理器”中,使用鼠标左键选中项目名称“Demo.Grpc.Cmd”,然后单击鼠标右键,在弹出的快捷菜单中选择“重新生成”......