分析 Go 语言与云原生技术
发布时间:2022-08-04 14:40:00 所属栏目:云计算 来源:互联网
导读:何为云原生 云原生(Cloud Native)概念是由Pivotal的Matt Stine在2013年首次提出的。 初探云原生,总给人一种模棱两可,不知所云的感觉。但实际上,云原生有着官方的定义: 这些技术能够构建容错性好、易于管理和便于观察的松耦合系统。结合可靠的自动化手
何为云原生 云原生(Cloud Native)概念是由Pivotal的Matt Stine在2013年首次提出的。 初探云原生,总给人一种模棱两可,不知所云的感觉。但实际上,云原生有着官方的定义: 这些技术能够构建容错性好、易于管理和便于观察的松耦合系统。结合可靠的自动化手段,云原生技术使工程师能够轻松地对系统作出频繁和可预测的重大变更。 这里我们精炼一下这个定义。 定义: 云原生软件是高度分布式的,必须在不断变化的环境中运行,并且本身也在不断变化的应用程序。 也就是说,云原生技术在面对环境的不确定性、需求的不断变化下,它们是可扩展的。 云原生的起源 这一切的根本原因可能都是来自网络发展带给的压力。 早期的时候,1950 年代后期大型机计算机的引入。当时,每个程序和数据块都存储在一台巨型机器中,用户可以通过愚蠢的终端访问,而没有自己的计算能力。所有的逻辑和所有数据都作为一个大的快乐整体生活在一起。 随着廉价网络连接的 PC 的到来,一切都在 1980 年代发生了变化。与愚蠢的终端不同,PC 可以自己进行一些计算,从而可以将某些应用程序的逻辑卸载到它们上。这种新的多层体系结构(分开的演示逻辑,业务逻辑和数据(图 1-1))首次可以将网络应用程序的组件进行修改或替换为独立于其他的网络应用程序的组件。 云原生软件的设计是为了预测故障并保持稳定,即使它所运行的基础设施正在经历故障或正在发生其他变化。 云原生目前已经包括了 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 之类的方法来改进应用程序,而不会破坏用户体验。 比如以下有名的应用全都是用 Go 实现: #云原生征文# 聊聊 Go 语言与云原生技术-开源基础软件社区 Docker 建立容器 Kubernetes 编排 Prometheus 事件监控 Consul 服务发现 Jaeger 端到端分布式跟踪 时至今日,Go 已经成为云原生开发的通用语言,从 Docker 到 Harbor,从 Kubernetes 到 Consul,从 InfluxDB 到 CockroachDB 等大部分是用 Go 编写的。而且每天都有更多的项目出现。 总结 总而言之,在传统的应用系统开发过程中,软件开发商喜欢聚焦在业务系统,专注于系统如何开发、如何闭源成一个独立的整体系统。 云原生技术的存在无非是为了能够利用“云”(数量)的好处,同时弥补其缺点(缺乏可靠性)。Go 语言很好地兼顾了开发效率和运行速度,不仅提供了高性能的运行时,也降低了大型项目的开发难度。 Go 语言发布至今已经有十余年,与云原生共同发展,有着大量工具和技术支持,熟练掌握 Go 语言之后再学习这些云原生工具,可能会有别样的体会。 (编辑:开发网_开封站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |