013.[转]云原生

badboyh2o badboyh2o     2022-12-09     119

关键词:

1. 什么是云原生

1.1 CNCF组织

在讲云原生之前,我们先了解一下CNCF,即云原生计算基金会,2015年由谷歌牵头成立,基金会成员目前已有一百多企业与机构,包括亚马逊、微软。思科等巨头。

目前CNCF所托管的应用已达14个,下图为其公布的Cloud Native Landscape,给出了云原生生态的参考体系。
技术图片

Cloud Native Landscape

1.2 云原生应用

https://www.jdon.com/performance/cloud-native.html

什么是原生云(cloud native)应用?

  原生云cloud-native应用的定义是:首先,应用系统应该与底层物理基础设施解耦。说白了,应用程序应该与操作系统等基础设施分离,不应该依赖Linux或Windows等底层平台,或依赖某个云平台。也就是说,应用从开始就设计为运行在云中,无论私有云或公有云;其次,该应用必须能满足扩展性需求,垂直扩展(向上和向下)或水平扩展(跨节点服务器)。

  cloud-native应用应该是容错的,为了能够扩展,需要异步处理请求,使用队列解耦功能。

  快速成为一个cloud-native应用可以使用Docker,可以在像亚马逊公有云和OpenStack私有云中部署。

  更官方定义是来自于Cloud Native Computing Foundation(CNCF)组织的定义,容器是CNCF推荐标准,这样服务能够运行在公有云和私有云之中。并能够在两者之间平滑迁移。Google作为CNCF成员,捐赠了其 Kubernetes 作为容器协调(container-orchestration)管理系统。

  当前cloud-native正在持续演进,最初始的两个特点:与基础设施解耦和垂直或上下扩展。如果这个目标不是很简单,那么可以用一句话概括:cloud-native的关键词就是微服务,运行在自己容器中微服务。其结果是导致一个环境:“用户驱动的系统”,包括标准化:标准化的部署和操作程序。

  微服务与容器的结合能够简化应用在各种计算环境中的部署。

 

 

 

CNCF给出了云原生应用的三大特征:
  • 容器化封装:以容器为基础,提高整体开发水平,形成代码和组件重用,简化云原生应用程序的维护。在容器中运行应用程序和进程,并作为应用程序部署的独立单元,实现高水平资源隔离。
  • 动态管理:通过集中式的编排调度系统来动态的管理和调度。
  • 面向微服务:明确服务间的依赖,互相解耦。

云原生包含了一组应用的模式,用于帮助企业快速,持续,可靠,规模化地交付业务软件。云原生由微服务架构,DevOps 和以容器为代表的敏捷基础架构组成。

这边引用网上关于云原生所需要的能力和特征总结,如下图。
技术图片

云原生所需要的能力和特征

1.3 The Twelve Factors

12-Factors经常被直译为12要素,也被称为12原则,12原则由公有云PaaS的先驱Heroku于2012年提出(https://12factor.net/),目的是告诉开发者如何利用云平台提供的便利来开发更具可靠性和扩展性、更加易于维护的云原生应用。具体如下:
  • 基准代码
  • 显式声明依赖关系
  • 在环境中存储配置
  • 把后端服务当作附加资源
  • 严格分离构建、发布和运行
  • 无状态进程
  • 通过端口绑定提供服务
  • 通过进程模型进行扩展
  • 快速启动和优雅终止
  • 开发环境与线上环境等价
  • 日志作为事件流
  • 管理进程

另外还有补充的三点:
  • API声明管理
  • 认证和授权
  • 监控与告警

距离12原则的提出已有五年多,12原则的有些细节可能已经不那么跟得上时代,也有人批评12原则的提出从一开始就有过于依赖Heroku自身特性的倾向。不过不管怎么说,12原则依旧是业界最为系统的云原生应用开发指南。

2. 容器化封装

最近几年Docker容器化技术很火,经常在各种场合能够听到关于Docker的分享。Docker让开发工程师可以将他们的应用和依赖封装到一个可移植的容器中。Docker背后的想法是创建软件程序可移植的轻量容器,让其可以在任何安装了Docker的机器上运行,而不用关心底层操作系统。

Docker可以解决虚拟机能够解决的问题,同时也能够解决虚拟机由于资源要求过高而无法解决的问题。其优势包括:
  • 隔离应用依赖
  • 创建应用镜像并进行复制
  • 创建容易分发的即启即用的应用
  • 允许实例简单、快速地扩展
  • 测试应用并随后销毁它们

自动化运维工具可以降低环境搭建的复杂度,但仍然不能从根本上解决环境的问题。在看似稳定而成熟的场景下,使用Docker的好处越来越多。

3. 服务编排

笔者看到Jimmy Song对云原生架构中运用服务编排的总结是:
Kubernetes——让容器应用进入大规模工业生产。
这个总结确实很贴切。编排调度的开源组件还有:Kubernetes、Mesos和Docker Swarm。

Kubernetes是目前世界上关注度最高的开源项目,它是一个出色的容器编排系统。Kubernetes出身于互联网行业的巨头Google公司,它借鉴了由上百位工程师花费十多年时间打造Borg系统的理念,通过极其简易的安装,以及灵活的网络层对接方式,提供一站式的服务。
Mesos则更善于构建一个可靠的平台,用以运行多任务关键工作负载,包括Docker容器、遗留应用程序(例如Java)和分布式数据服务(例如Spark、Kafka、Cassandra、Elastic)。Mesos采用两级调度的架构,开发人员可以很方便的结合公司业务场景自定制MesosFramework。
他们为云原生应用提供的强有力的编排和调度能力,它们是云平台上的分布式操作系统。在单机上运行容器,无法发挥它的最大效能,只有形成集群,才能最大程度发挥容器的良好隔离、资源分配与编排管理的优势,而对于容器的编排管理,Swarm、Mesos和Kubernetes的大战已经基本宣告结束,Kubernetes成为了无可争议的赢家。

4. 微服务架构

传统的Web开发方式,一般被称为单体架构(Monolithic)所有的功能打包在一个WAR包里,基本没有外部依赖(除了容器),部署在一个JEE容器(Tomcat,JBoss,WebLogic)里,包含了DO/DAO,Service,UI等所有逻辑。其架构如下图所示。
技术图片

传统的单体架构

单体架构进行演化升级之后,过渡到SOA架构,即面向服务架构。近几年微服务架构(Micro-Service Archeticture)是最流行的架构风格,旨在通过将功能模块分解到各个独立的子系统中以实现解耦,它并没有一成不变的规定,而是需要根据业务来做设计。微服务架构是对SOA的传承,是SOA的具体实践方法。微服务架构中,每个微服务模块只是对简单、独立、明确的任务进行处理,通过REST API返回处理结果给外部。在微服务推广实践角度来看,微服务将整个系统进行拆分,拆分成更小的粒度,保持这些服务独立运行,应用容器化技术将微服务独立运行在容器中。过去设计架构时,是在内存中以参数或对象的方式实现粒度细化。微服务使用各个子服务控制模块的思想代替总线。不同的业务要求,服务控制模块至少包含服务的发布、注册、路由、代理功能。

容器化的出现,一定程度上带动了微服务架构。架构演化从单体式应用到分布式,再从分布式架构到云原生架构,微服务在其中有着不可或缺的角色。微服务带给我们很多开发和部署上的灵活性和技术多样性,但是也增加了服务调用的开销、分布式系事务、调试与服务治理方面的难题。
技术图片

Spring Cloud整体架构图

从上图Spring Cloud组件的架构可以看出在微服务架构中所必须的组件,包括:服务发现与注册、熔断机制、路由、全局锁、中心配置管理、控制总线、决策竞选、分布式会话和集群状态管理等基础组件。
技术图片

Spring Cloud VS Kubernetes

Spring Cloud和Kubernetes有很大的不同,Spring Cloud和Kubernetes处理了不同范围的微服务架构技术点,而且是用了不同的方法。Spring Cloud方法是试图解决在JVM中的微服务架构要点,而Kubernetes方法是试图让问题消失,为开发者在平台层解决。Spring Cloud在JVM中非常强大,Kubernetes管理那些JVM很强大。看起来各取所长,充分利用这两者的优势是自然而然的趋势了。

5. 总结

技术架构的演变非常快,各种新的名词也是层出不穷。本文主要是对云原生的概述。云原生应用的三大特征:容器化封装、动态管理、面向微服务。首先由CNCF组织介绍了云原生的概念,然后分别对这三个特征进行详述。云原生架构是当下很火的讨论话题,是不同思想的集合,集目前各种热门技术之大成。

助力企业数据飞轮转起来!火山引擎云原生数仓bytehouse全面大促中

...据飞轮模式下“数据多样融合”环节的必要步骤之一。云原生数据仓库ByteHouse是火山引擎旗下基于开源ClickHouse的企业级分析型数据库,在字节跳动内部沉淀迭代多年后,凭借新一代的云原生架构,高效方便的运维模式,以及高... 查看详情

我奶奶都能看懂系列013python基础语法——类3(代码片段)

🌌专注Golang,Python语言,云原生,人工智能领域得博主;💜过去经历的意义在于引导你,而非定义你;📢欢迎点赞👍收藏⭐留言!前言01-继承的基本语法02-继承的分类03-子类重写父类... 查看详情

云原生是什么?云原生最近又火了

云原生最近又火了前言一、云原生是什么?二、云原生的核心三、云原生的正确打开方式四、云原生的优势前言    最近云原生特别的火,所以就特地了解了一下。本文主要记录云原生是什么,云原生的核心,... 查看详情

云原生容器技术1云原生容器技术概要介绍-云原生技术概述

阿里云容器ACP认证1云原生容器技术概要介绍-云原生技术概述参考https://edu.aliyun.com/lesson_2553_27357 查看详情

[云原生专题-1]:总体-云原生初步探究,什么是云原生,云原生的基本特性

...tps://blog.csdn.net/HiWangWenBing/article/details/122591920目录第1章云原生CloudNative的字面解读第2章云原生诞生的背景2.1云原生的诞生源于互联网业务发展的需求:2.2业务运营企业面临的挑战:2.3应对上述问题的技术和软件工程措施... 查看详情

云原生容器技术2云原生容器技术概要介绍-云原生容器技术概述

参考https://edu.aliyun.com/lesson_2553_27358#_27358 查看详情

云原生是什么

文章目录01什么是云原生02云原生计算基金会(CloudNativeComputingFoundation,CNCF)03云原生的作用04如何拥抱云原生技术05云原生适合大企业还是小企业06云原生与开源参考文献导读:CloudNative:云原生。我们今天一起来聊... 查看详情

云原生概述

这里写自定义目录标题一、云原生概述1、定义2、云原生的设计理念3、云元素的四要二、如何云原生一、云原生概述1、定义云原生(CloudNative)这个词汇由来已久,以致于何时出现已无据可考。云原生开始大规模出现... 查看详情

阿里云李飞飞:什么是云原生数据库

简介: 云原生是一种新型技术体系,是云计算未来的发展方向。今天,阿里云李飞飞将和我们分享何为云原生、云原生如何与分布式有机结合,以及云原生技术如何帮助客户迈入数字原生时代。作者|飞刀来源|阿里技术公众... 查看详情

kubernetes和云原生

1.云原生相关1.1.什么是云原生CloudNative最早是在2013年由Pivotal公司的MattStine提出的。2015年CNCF(CloudNativeComputingFoudation,云原生计算基金会)成立。官方发布的云原生v1.0定义是:“云原生技术有利于各组织在公有云、私有云和混合... 查看详情

为什么k8s在阿里能成功(转)

 作者:曾凡松阿里云云原生应用平台高级技术专家张振阿里云云原生应用平台高级技术专家导读:本文描述了阿里巴巴在容器管理领域的技术演进历程,解读了为什么K8s最终能够大获成功的原因,以及到今年双11阿里巴巴内... 查看详情

从阿里云容器攻防矩阵&api安全生命周期,看如何构建金融安全云原生平台

【编者按】云原生技术正在助力银行通过差异化业务进行创新,却也带来了由于研发/运维人员对新架构不熟悉所导致的基础设施风险、业务风险及数据暴露风险。如何在飞速更迭的技术环境下保持业务持续发展,同时保... 查看详情

腾讯云发布三款云原生新品持续加码云原生布局

随着云原生热度持续攀升,行业进入云上价值探索的新阶段。10月29日,在TechoDay腾讯技术开放日上,腾讯宣布升级云原生战略布局,加大PaaS自研能力建设,并发布了三款云原生新品,表示将持续加大对云... 查看详情

腾讯云发布三款云原生新品持续加码云原生布局

随着云原生热度持续攀升,行业进入云上价值探索的新阶段。10月29日,在TechoDay腾讯技术开放日上,腾讯宣布升级云原生战略布局,加大PaaS自研能力建设,并发布了三款云原生新品,表示将持续加大对云... 查看详情

云原生和云计算是什么?两者有何区别?

...续学习,就很容易被新人所替代,今天给大家讲解一下云原生与云计算的区别,以下是详细的内容:  云原生是什么?  云原生其实在业界没有绝对统一的定义,但是基本上的理解我们可以理解为如下:云+原生,云的意思是... 查看详情

从云原生看社会发展

从云原生看社会发展前言一、百度云、阿里云、腾讯云、华为云擅长领域二、云原生的未来发展直接影响的五大领域三、人工智能、云计算、大数据、物联网、5G之间的关系前言    上一篇文章讲了云原生,云原生(CloudNative... 查看详情

阿里云发布云原生加速器,携手生态企业拥抱数字时代

简介: 继去年推出云原生合作伙伴计划之后,阿里云正式发布云原生加速器,携手生态企业拥抱数字时代。今天,千行百业都在拥抱云计算、拥抱云原生,进行数字化创新升级。作为国内最早实践云原生的企... 查看详情

阿里云发布云原生加速器,携手生态企业拥抱数字时代

简介:继去年推出云原生合作伙伴计划之后,阿里云正式发布云原生加速器,携手生态企业拥抱数字时代。今天,千行百业都在拥抱云计算、拥抱云原生,进行数字化创新升级。作为国内最早实践云原生的企... 查看详情