聊聊 Go 语言与云原生技术

聊聊 Go 语言与云原生技术

作者:宇宙之一粟 2022-06-22 09:24:30

云计算

云原生 云原生软件是高度分布式的,必须在不断变化的环境中运行,并且本身也在不断变化的应用程序。

​​想了解更多关于开源的内容,请访问:​​

​​51CTO 开源基础软件社区​​

​​https://ost.IDC.NET​​

何为云原生

云原生(Cloud Native)概念是由Pivotal的Matt Stine在2013年首次提出的。

初探云原生,总给人一种模棱两可,不知所云的感觉。但实际上,云原生有着官方的定义:

根据 云原生计算基金会 (CNCF,著名的 Linux 基金会的一个子基金会)的说法:

云原生技术有利于各组织在公有云、私有云和混合云等新型动态环境中,构建和运行可弹性扩展的应用。云原生的代表技术包括容器、服务网格、微服务、不可变基础设施和声明式 API。

这些技术能够构建容错性好、易于管理和便于观察的松耦合系统。结合可靠的自动化手段,云原生技术使工程师能够轻松地对系统作出频繁和可预测的重大变更。

这里我们精炼一下这个定义。

定义: 云原生软件是高度分布式的,必须在不断变化的环境中运行,并且本身也在不断变化的应用程序。

也就是说,云原生技术在面对环境的不确定性、需求的不断变化下,它们是可扩展的。

云原生的起源

这一切的根本原因可能都是来自网络发展带给的压力。

  1. 早期的时候,1950 年代后期大型机计算机的引入。当时,每个程序和数据块都存储在一台巨型机器中,用户可以通过愚蠢的终端访问,而没有自己的计算能力。所有的逻辑和所有数据都作为一个大的快乐整体生活在一起。
  2. 随着廉价网络连接的 PC 的到来,一切都在 1980 年代发生了变化。与愚蠢的终端不同,PC 可以自己进行一些计算,从而可以将某些应用程序的逻辑卸载到它们上。这种新的多层体系结构(分开的演示逻辑,业务逻辑和数据(图 1-1))首次可以将网络应用程序的组件进行修改或替换为独立于其他的网络应用程序的组件。
  3. 在 1990 年代,万维网的普及和随后的“互联网”淘金热将世界介绍给软件作为服务(SaaS)。整个行业都是建立在 SaaS 模型上的,推动了更复杂和渴望资源的应用程序的开发,这些应用程序反过来又更加努力地开发,维护和部署。突然间,经典的多层建筑已经不够了。作为回应,业务逻辑开始分解为可以独立开发,维护和部署的子组件,并迎来了微服务时代。
  4. 2006 年,亚马逊推出了 Amazon Web Services(AWS),其中包括 Elastic Compute Cloud(EC2)服务。尽管 AWS 不是作为服务(IAAS)提供的第一个基础架构,但它彻底改变了数据存储和计算资源的按需可用性,从而使云计算以及快速扩展的能力 – 促进了群众的大规模迁移资源进入”云”。

云原生软件的设计是为了预测故障并保持稳定,即使它所运行的基础设施正在经历故障或正在发生其他变化。

云原生目前已经包括了 DevOps(Development 和 Operations 的组合)、持续交付( Continuous Delivery,CD)、微服务( MicroServices )、敏捷基础设施( Agile Infrastructure )和十二要素( The Twelve-Factor App )等几大主题。

云原生特性

云原生应用程序的设计和构建是为了利用云提供的规模(scale),弹性(resiliency),适用性(resiliency)和灵活性(flexibility)。

如今复杂应用程序的特点(用户期望连续创新以及无与伦比的响应能力)使业务系统更具战略性和越来越灵活。云原生就是要快速响应,同时还保持敏捷。

云原生应用的好处

云原生应用(Native cloud applications,NCAs)是为云计算体系结构设计的程序。他们有很多好处:

  • 独立性:他们的架构使得可以彼此独立地构建云原生应用。这意味着您还可以单独管理和部署它们。
  • 弹性:精心设计的云原生应用即使在基础架构中断也能够生存和在线。
  • 基于标准的:对于互操作性和工作负载可移植性,云原生应用服务通常基于开源和标准技术。这有助于减少供应商的锁定,并增加可移植性。
  • 业务敏捷性:云原生应用可在整个网络上启用灵活的部署选项,并且比传统应用程序还小,这使得它们更易于开发,部署和迭代。
  • 自动化:云原生应用使用 DevOps 自动化功能,并启用定期发布的软件更改的连续交付和部署。此外,开发人员可以使用诸如 Blue-green deployment 和 Canary Deployment 之类的方法来改进应用程序,而不会破坏用户体验。
  • 零停机时间:由于诸如 Kubernetes 之类的容器编排,您可以通过基本零停机时间部署软件更新。

Go 在云原生时代的优势

Go 云原生开发有着天然的优势,云原生系统需要可扩展、耦合、弹性可管理。Go 的设计就是为云原生时代构建的语言,简单高效 、快速编译、支持现代网络和多核计算、支持高并发、内存安全,帮助用户专注于解决问题而不是受限于语言的复杂性。

比如以下有名的应用全都是用 Go 实现:

  • ​​Docker​​ 建立容器
  • ​​Kubernetes​​ 编排
  • ​​Prometheus​​ 事件监控
  • ​​Consul​​ 服务发现
  • ​​Jaeger​​ 端到端分布式跟踪

时至今日,Go 已经成为云原生开发的通用语言,从 Docker 到 Harbor,从 Kubernetes 到 Consul,从 InfluxDB 到 CockroachDB 等大部分是用 Go 编写的。而且每天都有更多的项目出现。

总结

总而言之,在传统的应用系统开发过程中,软件开发商喜欢聚焦在业务系统,专注于系统如何开发、如何闭源成一个独立的整体系统。

云原生技术的存在无非是为了能够利用“云”(数量)的好处,同时弥补其缺点(缺乏可靠性)。Go 语言很好地兼顾了开发效率和运行速度,不仅提供了高性能的运行时,也降低了大型项目的开发难度。

Go 语言发布至今已经有十余年,与云原生共同发展,有着大量工具和技术支持,熟练掌握 Go 语言之后再学习这些云原生工具,可能会有别样的体会。

最后,学习和了解 Go 与云原生技术,提升知识面,帮助我们更加能抓住行业的机会,时不我待。

参考链接:

  • ​​What is Cloud Native?​​
  • ​​What Is a “Cloud Native” Application?​​
  • ​​Cloud Native Computing Foundation​​ ,CNCF

​​想了解更多关于开源的内容,请访问:​​

​​51CTO 开源基础软件社区​​

​​https://ost.IDC.NET​​。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/280746.html<

(0)
运维的头像运维
上一篇2025-05-12 16:18
下一篇 2025-05-12 16:20

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

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