云原生(Cloud native)

云原生(Cloud native)

一 定义

目前比较权威的定义主要来自Pivotal公司和云原生计算基金会(Cloud Native Computing Foundation,简称CNCF)。

1.1 Pivotal

  • 4个要点:
    DevOps持续交付微服务容器化
  • 六个特质:
    模块化(Modularity)可观测性(Observability)可部署性(Deployability)
    可测试性(Testability)可处理性(Disposability)可替换性(Replaceability)
  • 云原生是一个思想的集合,既包含技术(微服务,敏捷基础设施),也包含管理(DevOps、持续交付、康威定律以及重组等),云原生是一系列云技术、企业管理方法的集合。

1.2 CNCF

  • 云原生技术有利于各组织在公有云、私有云和混合云等新型动态环境中,构建和运行可弹性扩展的应用。
  • 云原生的代表技术包括容器、服务网格、微服务、不可变基础设施和声明式API。这些技术能够构建容错性好、易于管理和便于观察的松耦合系统。
  • 结合可靠的自动化手段,云原生技术使工程师能够轻松地对系统作出频繁和可预测的重大变更。

二 技术特点

2.1 微服务架构:

云原生化倡导使用微服务架构来构建应用程序,将应用程序拆分为多个小型、独立且可独立部署的服务,每个服务专注于解决特定的业务功能。这样可以提高应用程序的可扩展性、灵活性和可维护性。

2.2 容器化部署:

云原生应用程序通常使用容器技术(如Docker)进行部署,通过将应用程序及其依赖打包为容器镜像,实现跨平台、可移植和一致的部署。容器化还提供了隔离性和资源利用率的优势,使应用程序能够更高效地运行。

2.3 动态编排和自动化管理:

云原生化强调使用自动化工具和平台(如Kubernetes)来进行应用程序的动态编排和管理,自动化地管理容器的部署、伸缩、升级和监控等操作,提高应用程序的弹性和可靠性,并减少人工操作的复杂性。

2.4 弹性伸缩:

云原生化允许应用程序根据负载情况进行弹性伸缩,通过自动化的容器编排和服务发现,动态地添加或移除容器实例,以适应不同的负载变化,提高应用程序的性能和资源利用率。

2.5 持续交付和部署:

云原生化倡导使用持续集成和持续交付(CI/CD)的方法来实现应用程序的快速交付和部署,通过自动化的构建、测试和部署流程,快速、可靠地将应用程序更新推送到生产环境,减少发布的风险和时间成本。


三 技术栈

3.1 容器化

  • 容器引擎:如Docker,是一种开源的应用容器引擎,它将应用程序及其依赖打包成标准化的容器镜像。容器镜像可以在任何支持Docker的环境中运行,确保应用在开发、测试和生产环境之间的一致性。
  • 容器运行时:如containerd或runc,负责容器的生命周期管理,包括容器的创建、启动、停止、删除等操作,以及与宿主机的资源交互。
  • 容器编排:如Kubernetes(K8s),是目前最流行的容器编排平台,提供了一套强大的API和工具集,用于自动化容器的部署、调度、扩缩容、负载均衡、滚动升级、自我修复、服务发现、配置管理等操作。

3.2 微服务架构

  • 微服务:将大型单体应用分解为一组小型、独立的服务,每个服务专注于单一业务功能,通过API进行交互。微服务之间通过轻量级的通信机制(如RESTful API、gRPC等)互相协作,有助于提升开发速度、降低耦合度、增强系统的可伸缩性和容错能力。

3.3 服务间通信

  • RESTful API:
    基于HTTP协议和其各种方法(GET、POST、PUT、DELETE等),遵循资源导向的架构风格设计接口,广泛应用于微服务间的交互。
  • gRPC:
    由Google开发的一种高性能、通用的RPC(Remote Procedure Call)框架,基于HTTP/2协议和Protocol Buffers序列化协议,适用于对性能和效率要求较高的场景。
  • 消息队列:
    如RabbitMQ、Apache Kafka、Amazon SQS等,作为异步通信中间件,用于解耦服务、处理峰值负载、实现事件驱动架构。

3.4 服务网格

  • 服务网格技术:
    如Istio、Linkerd、Envoy等,位于服务之间,作为一层透明的基础设施层,负责服务间的网络通信、路由、安全、可观测性等功能。服务网格抽象了服务间通信的复杂性,使得开发者无需在应用代码中实现这些功能。

3.5 持续集成与持续部署(CI/CD)

  • CI/CD工具:
    如Jenkins、GitLab CI/CD、GitHub Actions、Azure DevOps等,用于自动化软件开发的构建、测试、打包、发布和部署流程。CI/CD实践有助于缩短迭代周期、提高软件质量、减少人工干预带来的错误。

3.6 声明式基础设施

  • 声明式配置:
    使用YAML或JSON格式的配置文件来描述应用部署的目标状态,如Kubernetes的YAML manifests。开发者只需定义期望的状态,系统会自动处理如何达到这个状态。
  • 基础设施即代码(IaC)管理工具:
    如Terraform、CloudFormation等,用于跨云平台的基础设施管理,实现基础设施的版本控制、自动化部署和一致性管理。

3.7 DevOps工具链

  • 日志聚合:
    如ELK Stack(Elasticsearch、Logstash、Kibana)、Splunk、Datadog等,用于收集、解析、存储、搜索、分析和可视化日志数据。
  • 监控:
    如Prometheus、Grafana、New Relic、Dynatrace等,提供系统和应用性能监控。
  • 错误追踪:
    如Sentry、Bugsnag、Rollbar等,用于捕获、分析和管理应用运行时的异常和错误。
  • 混沌工程:
    如Chaos Monkey、Chaos Toolkit等,通过主动在生产环境中引入故障,测试系统在异常条件下的表现和恢复能力。

3.8 无服务器计算(Serverless)

  • 无服务器服务:
    如AWS Lambda、Google Cloud Functions、Azure Functions等,允许开发者编写和运行代码片段(函数),无需关心底层服务器的运维,仅在函数被触发时按需执行并计费。

四 应用场景

云原生技术在多个领域都有广泛的应用前景,包括但不限于:

  • 大规模互联网应用:构建高可用性、高性能和高可扩展性的互联网应用。
  • 金融业务:提供安全、可靠、高效的应用程序开发和部署方式,提高金融业务应用的可靠性和安全性。
  • 人工智能和大数据:为AI和大数据应用提供高效、可扩展、弹性伸缩的应用程序开发和部署方式。
  • 物联网:处理海量的传感器数据,实现快速部署和弹性伸缩,提高物联网应用的可靠性和可维护性。
  • 区块链:为区块链应用提供高效、可扩展、弹性伸缩的应用程序开发和部署方式。

以上就是云原生的全部内容,感谢阅读!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java后端】Service层读取yml配置文件中内容

前言 最近写代码,看到别人写的读取application.yml配置文件中数据,写的挺规范,挺好的;虽然之前也读取过yml文件,但用的其他方法,没这个规范,所以记录下 正文 假设要读取视频地址,…

微信小程序切换商户号

1.登录微信公众平台小程序 2.功能->微信支付 3.关联成功后会志一关联商户号列表显示 4.登录你需要切换的商户号 在下面选择你需要开通的产品服务 5.切换到账户中心的api安全里面 只需要改变当前下面的配置即可切换小程序的收款商户号 申请API证书按照官方的指引即可解…

关于redis的运维面试题-2

21. Redis的客户端连接数限制如何设置? 在Redis中,客户端连接数的限制可以通过配置文件redis.conf来设置,也可以通过命令行直接设置。以下是如何通过配置文件和命令行来设置Redis客户端连接数限制的步骤和示例代码。 通过配置文件设置客户端…

JS计算某一年的土地租金收入和土地承租支出

涉及到多年的地租 , 例如 2024年5月15日 - 2026年5月15日 , 总承包租金是60000 假设 当前年是2024年 , 则计算2024年5月15日-2024年12月31日的租金收入 , 如果是2025年则是2025年1月1日-2025年12月31日 //示例交易数据 var transactions [ { type: "转出土地收益&qu…

怎么区分住宅IP还是机房IP?机房IP和住宅IP有哪些不同?

在网络技术的应用中,IP地址扮演着至关重要的角色。了解IP地址的种类及其特性,对于进行网络管理、优化网络安全策略、以及实施数据分析等任务至关重要。本文将深入探讨如何区分住宅IP和机房IP,并分析两者的主要差异。 一、IP地址分类简介 IP…

pytorch-RNN存在的问题

这里写目录标题 1. RNN存在哪些问题呢?1.1 梯度弥散和梯度爆炸1.2 RNN为什么会出现梯度弥散和梯度爆炸呢? 2. 解决梯度爆炸方法3. Gradient Clipping的实现4. 解决梯度弥散的方法 1. RNN存在哪些问题呢? 1.1 梯度弥散和梯度爆炸 梯度弥散是…

【人工智能】深度学习:神经网络模型

【人工智能】深度学习:神经网络模型 神经网络基础知识 BP神经网络的概念 单个神经元的结构 CNN模型汇总 LeNet5 模型 AlexNet 模型 VGG模型 Inception Net(GoogleNet)模型 ResNet (残差网络) RNN模型&#x…

css实现渐进中嵌套渐进的方法

这是我们想要的实现效果: 思路: 1.有一个底色的背景渐变 2.需要几个小的块级元素做绝对定位通过渐变filter模糊来实现 注意:这里的采用的定位方法,所以在内部的元素一律要使用绝对定位,否则会出现层级的问题&…

小白攻克歌曲“无名的人”,逐句精研的歌唱诀窍

《无名的人》 作词:唐恬 作曲:钱雷 演唱:毛不易 今天不讲解练习技巧,有需要的可以查看往期文章,我给大家带一下无名的人,练习一下情感融入。 对于众多唱歌小白而言,学习歌曲《无名的人》是一…

ctfshow-web入门-文件上传(web164、web165)图片二次渲染绕过

web164 和 web165 的利用点都是二次渲染,一个是 png,一个是 jpg 目录 1、web164 2、web165 二次渲染: 网站服务器会对上传的图片进行二次处理,对文件内容进行替换更新,根据原有图片生成一个新的图片,这样…

【Linux】进程优先级 + 环境变量

前言 在了解进程状态之后,本章我们将来学习一下进程优先级,还有环境变量等。。 目录 1.进程优先级1.1 为什么要有优先级? 2.进程的其他概念2.1 竞争性与独立性2.2 并行与并发2.3 进程间优先级的体现:2.3.1 O(1) 调度算法&#xf…

Apache Web安全分析与增强

Apache HTTP Server 概述 Apache HTTP Server(通常简称为Apache)是一个开源的Web服务器软件,由Apache软件基金会开发和维护。它是全球使用最广泛的Web服务器之一,支持多种操作系统,包括Unix、Linux、Windows和Mac OS X。以下是Apache Web服务器的详细概述,包括其功能特点…

数字高压表0-30kv

最近在制作数字高压表,自己DIY玩玩,有没有朋友一起研究看看

SpringCloud--常用组件和服务中心

常用组件 Euroke和nacos 区别 负载均衡 负载均衡策略有哪些 自定义负载均衡策略

【Red Hat 4.6---详细安装Oracle 19c】---静默方式安装

🔻 一、安装前规划 规划项:(本环境) 描述:操作系统版本Red Hat Enterprise Linux Server release 4.6 (Santiago)主机名langtest数据库版本 Oracle 19c IP规划10.10.10.164服务器空间要求根据实际要求数据库名/实例名orcl数据库块大小oracle建库一般设置数据库块大…

物业系统自主研发接口测试框架

1、自主研发框架整体设计 1.1、什么是测试框架? 在了解什么是自动化测试框架之前,先了解一下什么叫框架?框架是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是可被应用开发者定制的应用骨架…

Redis 主从复制,集群与高可用

虽然Redis可以实现单机的数据持久化,但无论是RDB也好或者AOF也好,都解决不了单点宕机问题,即一旦单台 redis服务器本身出现系统故障、硬件故障等问题后,就会直接造成数据的丢失 此外,单机的性能也是有极限的,因此需要使用另外的技…

捷配生产笔记-细间距芯片的表面处理工艺:OSP与沉金工艺的重要性

在现代电子制造领域,随着技术的进步,电子设备变得越来越小型化和高性能化。细间距芯片作为实现这一目标的关键组件,其制造工艺要求极为严格。在这些要求中,表面处理工艺尤为关键,因为它直接影响到芯片的焊接质量和长期…

江苏云服务器适用于哪些场景?

云服务器主要是指一中基于云计算技术的虚拟化服务器,用户能够通过互联网网络进行远程访问和管理,与传统的物理服务器相比较,云服务器更具有可扩展性与灵活性,所以云服务器受到越来越多的企业所使用,同时在各个领域中都…

实验7 数据查询(2)

一、实验目的 学习SQL语言的定义、操纵功能熟悉通过SQL语言对数据库进行查询操作,包括单表查询、多表查询、嵌套查询、集合查询 二、实验软件 MySQL三、实验内容和要求 给定四个关联表,其定义和数据加载如下: 学生表 Student create tab…