云原生架构概念

云原生架构概念

云原生架构(Cloud Native Architechtrue)作为一种现代软件开发的革新力量,正在逐渐改变企业构建、部署和管理应用程序的方式。它的核心优势在于支持微服务架构,使得应用程序能够分解为独立、松耦合的服务,每个服务都可以单独开发、部署和扩展,从而提高了敏捷性和迭代速度。此外,云原生架构通过容器化技术,如Docker和Kubernetes,确保了应用程序在不同环境中的一致性和便捷性,同时促进了持续集成和持续部署(CI/CD)的实践,加快了软件发布的速度并降低了风险。

云原生架构还带来了自动化运维(DevOps)的实践,通过自动化的测试、集成和部署流程,提升了软件交付的效率和质量。这种架构的弹性、自动化和安全性是其关键特点,它能够根据负载自动扩展或缩减资源,提高了应对突发流量的能力。

在实际案例中,诸如腾讯云原生产品体系和架构已经非常完善,涵盖了软件研发流程、计算资源、架构框架、数据存储和处理、安全等五大领域的多个场景。腾讯云原生的定位是成为企业数字化的助推器,让用云“更简单”,利用云厂商在技术和资源的规模化效应,降低企业成本,提高企业的效率。

云原生的特征和优势

通俗来讲,“云原生“主要是和“将传统应用程序简单地迁移到云上”是两种相对的方式。“云原生”叫法来自于术语,其中的“云”指的是云计算,而“原生”则意味着“原生的”或“本地的”。将这两个词组合在一起,"云原生"(Cloud Native)指的是专门为云计算环境设计和优化的应用程序和架构。就是指在软件设计之初考虑云环境,以云服务作为基础,基于云计算平台的特性进行软件架构的设计。

两种方式的区别:

  1. 云原生(Cloud Native)

    • 设计原则:云原生应用程序从设计之初就考虑到了云计算的特性,如弹性、分布式、可扩展性等。
    • 技术栈:通常使用容器、微服务、持续集成/持续部署(CI/CD)等现代技术栈。
    • 架构:采用微服务架构,将应用程序分解为独立的、松耦合的服务,每个服务都可以独立部署和扩展。
    • 运维:采用DevOps文化,开发和运维团队紧密合作,实现快速迭代和自动化部署。
    • 云服务利用:充分利用云计算平台提供的各种服务,如计算、存储、数据库、消息队列等。
  2. 传统应用程序迁移到云上

    • 设计原则:这些应用程序最初是为传统的物理服务器或虚拟机环境设计的,可能没有充分考虑云计算的特性。
    • 技术栈:可能仍然使用传统的技术栈,如单体应用程序、传统的数据库等。
    • 架构:可能是单体架构,整个应用程序作为一个整体部署和运行,难以实现真正的水平扩展。
    • 运维:可能仍然采用传统的开发和运维分离的模式,部署和更新过程可能较为缓慢和复杂。
    • 云服务利用:可能只是将应用程序简单地部署到云服务器上,没有充分利用云计算平台提供的各种服务。

云原生架构的目标是提高应用程序的可扩展性、可靠性和灵活性,同时降低运维成本和提高开发效率。这种架构特别适合需要快速迭代和能够应对高流量波动的现代应用程序

云原生架构通俗化理解

让我们用一个餐厅的例子来通俗地解释云原生架构。

想象一下,你开了一家餐厅,这家餐厅的特点就是能够快速适应顾客的需求变化,并且能够灵活地提供各种菜品。

  1. 容器化:就像你把不同的菜品放在不同的容器里(比如盘子、碗、锅),每个容器都是独立的,可以轻松地移动和清洗。在云原生中,应用程序的每个部分(比如用户界面、数据库、支付处理)都被打包在自己的容器里。

  2. 微服务架构:你的餐厅不是只有一个大厨房,而是有多个小厨房,每个厨房负责一种或几种特定的菜品。这样,如果某个厨房需要升级或维护,其他厨房仍然可以继续工作,不会影响整个餐厅的运营。

  3. 动态管理:餐厅的顾客数量会根据时间(比如午餐时间或晚餐时间)而变化。云原生架构允许你的餐厅根据顾客数量自动增加或减少厨师和服务员的数量,以确保服务质量。

  4. CI/CD:每当厨师开发出新菜品或者改进了现有菜品,他们可以立即将这些变化送到顾客面前,而不需要等待很长时间。

  5. DevOps文化:厨师和服务员不再是分开工作的,他们一起讨论如何改进菜品和服务,确保顾客满意。

  6. 可观察性:餐厅的每个角落都装有摄像头,这样你可以随时监控餐厅的运营情况,比如哪个菜品最受欢迎,哪个环节出现了问题。

  7. 弹性:即使某个厨房出现了问题,其他厨房仍然可以继续工作,顾客不会注意到任何中断。

  8. API驱动:厨房和服务员之间通过特定的指令(API)来沟通,比如“需要一份宫保鸡丁”,这样即使服务员和厨师不是直接交流,也能确保信息准确传达。

总的来说,云原生架构就像是一家能够快速适应变化、灵活运营、并且能够提供高质量服务的餐厅。

一些著名的云原生案例

以下是一些著名的云原生架构实践案例:

  1. Alibaba Cloud:作为亚太地区领先的云服务提供商,Alibaba Cloud 采用了云原生架构来提高网络性能和可扩展性。

  2. Seznam:Seznam 是捷克共和国最大的互联网公司之一,每天处理超过一百万的 HTTP 请求。通过采用云原生技术,Seznam 能够提高性能并降低成本。

  3. Infosys client:通过 Kubernetes 和 KEDA,Infosys 的客户成功地将大型机迁移到 Azure 云,实现了显著的成本节约。

  4. Kakao:韩国的 IT 服务公司 Kakao 通过使用 Cilium 改善了网络性能并降低了成本。

  5. Grafana Security:Grafana Security 利用 Dapr 改进了漏洞扫描,自项目开始以来发现了超过 698,000 个问题。

这些案例展示了云原生架构在不同行业和应用场景中的广泛适用性和效益。通过采用云原生架构,组织能够提高其应用程序的灵活性、可扩展性和可靠性,同时降低运维成本和提高开发效率。

在学术研究方面,有关云原生应用的系统映射研究(Systematic Mapping Study)提供了对云原生应用(CNA)的原则、架构和方法论的深入分析,并讨论了现有研究的工程趋势和未来研究方向。此外,还有研究探讨了云原生架构特性对软件质量的影响,并通过验证调查进行了研究。这些研究为理解和实施云原生架构提供了理论基础和实践指导。

相关技术

1 容器云

容器是一种使用灵活、方便打包各种依赖并且移植性强的软件技术,当今市场上越来越多的应用都在使用此技术,通过该项能力可以方便各种服务以相同的方式运行在不同的操作系统上。

容器云是一种以容器化为基础的应用部署模式,它可以更轻松和更快捷地将应用部署到云端。使用该技术的应用可以被拆分成多个组件,每个组件都有自己的功能,可以以容器的形式运行,可以在云端自动部署和扩展,从而提供更高的可用性和更好的性能,并有助于实现更便捷的产品迭代和更快的应用上线。

系统使用容器云技术有如下的优势:

        (1)平台化的基础设施管理:全面集成 Kubernetes 容器编排引擎,执行统一管理,并提供全面的容器网络与容器存储解决方案,形成平台化的基础设施;

        (2)高效的容器服务:使用容器管理应用,实现快速部署和节省资源占用的同时,还具备灵活的应用编排和交付能力,保证在多场景下交付应用。该技术支持将容器运行在 Docker 和 Containerd 两类容器中;

        (3)自动化运维管理:提供以应用为中心的智能运维体验,屏蔽基础运维架构,使用户更专注于核心业务;

        (4)服务化的 IT 治理:支持多租户管理场景,实现细粒度权限控制和自助IT 治理。统一管理和监控不同基础设施环境上的资源,通过安全审计机制,保障系统安全性;

        (5)开箱即用的数据库和消息队列服务:简化数据库和消息队列服务的构建、部署和运行过程,帮助用户更便捷地管理和使用数据库及消息队列。

2 DevOps

DevOps 是一种软件开发实践,在基于 DevOps 理念建设系统的过程中,开发人员(Dev)和运维人员(Ops)之间紧密协作。该技术提供包含流水线管理、代码仓库纳管和制品管理等在内的开箱即用一站式服务,能够帮助企业专注于业务目标,提升企业内研发、测试和运维能力,保障业务的连续性、安全性和敏捷性,实现自动化部署和运维,缩短开发周期,提高部署频率,轻松应对瞬息万变的市场需求。

具体来说 DevOps 有以下特点:

(1)提供开放式的 DevOps 工具链选型,深度集成敏捷项目管理,如集成禅道管理工具,另外可以集成 GitLab 代码管理工具,实现代码的内部统一管理,并且 DevOps 体系也能兼容企业已有的工具,从而对 DevOps 进行灵活实践。

(2)DevOps 强调产品管理、自动化软件交付和灵活应对基础设施的变更,旨在缩短产品开发周期,提高部署频率,紧密结合业务目标支撑应用的全生命周期,为企业建立起高效可靠的测试发布文化与环境。

(3)以 Jenkins 作为实现持续集成/持续交付(CI/CD)的标准工具,助力实现更敏捷可靠的应用发布,加快产品迭代速度,使企业更专注于核心业务目标。

DevOps 产品的整体结构如图所示。

3 Service Mesh 技术

Service Mesh 是新一代的微服务治理平台,支持Istio 和Spring Cloud两种主流的微服务框架,该治理平台为云原生提供了一整套稳定、可靠和开放的微服务解决方案。平台的一键式基础设施部署升级能力、可视化服务治理能力和高效的应用性能管理能力,以及高可用的微服务网关管理能力,能够极大提升服务治理效率,从而全面降低维护微服务框架的成本。同时,可减少开发人员对框架的依赖,让开发人员聚焦于业务开发,不断提升核心竞争力。

具体来说该技术在微服务治理方面有如下特点:

(1)构建分布式微服务系统:通过分布式微服务架构取代传统的单体应用架构,满足快速扩容、弹性伸缩、敏捷迭代和快速交付等新型业务的诉求。

(2)自动化灰度发布:基于动态流量策略,实现应用及服务的自动化灰度发布,满足金丝雀和蓝绿等多种灰度发布场景。

(3)可靠的服务治理:提供丰富的可视化治理策略,动态配置服务路由、服务熔断、服务限流和负载均衡规则,覆盖大部分微服务治理场景。

(4)服务全局可视化:基于流量监控数据,全局展示服务间的调用关系和调用性能。通过从全局聚焦到局部,可为服务调优、服务排障和下钻分析等场景提供多维度监控分析能力。

(5)“多地多中心”业务容灾:基于“多主”架构的服务网格,支持纳管多个集群,多个集群之间完全独立。任一集群故障,不会影响到网格下其他集群的工作。服务可部署在网格纳管的任意集群中。当某个集群下的服务因故障触发熔断后,服务在该集群下的部分入口流量将转移至其他集群,由其他集群上的服务负载,以保障服务整体的负载性能稳定。并可根据集群的实际地域分布,自定义容灾负载优先级。

(6)灵活的多网关(网关多端口)管理:支持为服务网格配置多个入口或出口网关,每个网关允许通过多个端口访问。其中,入口网关支持通过不同的路由场景将外部流量路由到不同的后端资源;出口网关可实现网格内服务对外部服务的访问管理及流量监控。并且可满足业务区域之间网络隔离、业务独占网关和端口隔离等丰富的使用场景。同时,对于不再需要的网关可轻松无损下线。除此之外,Service Mesh 还可基于网关的黑白名单和JWT 对发起请求的客户端进行身份认证与鉴权,并根据请求路径、请求 Header 和URI 重写等多样化的方式配置路由规则。Service Mesh 还支持实例级别的网关监控,配合多种内置告警策略,可帮助用户及时发现问题。具体的 Service Mesh 产品结构如图所示。
 

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

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

相关文章

window系统怎么设置闹钟提醒?分享一个桌面提醒设置办法

在日常工作和生活中,我们常常会因忙碌而遗忘一些重要事项。对于很多使用电脑办公的用户来说,如果能在桌面上设置闹钟提醒,无疑会大大提高工作效率,减少遗漏。那么,如何设置这样的闹钟提醒呢? 这时&#xf…

ElementUI实现el-table组件的合并行功能

前言 有时遇到一些需求,需要实现ElementUI中,el-tabled组件合并单元格的功能,稍微了解一下它的数据格式,不难可以写出比合并方法。但是在鼠标经过单元行时,会出现高亮的行与鼠标经过的行不一致的BUG。因此还需要实现c…

8月刷题笔记

刷题笔记—8月 LCP40.心算挑战(贪心、排序) class Solution { public:int maxmiumScore(vector<int>& cards, int cnt) {//24.8.1ranges::sort(cards, greater()); //从大到小排序int s reduce(cards.begin(), cards.begin()cnt, 0);if(s%2 0) return s;auto rep…

无线麦克风哪个牌子的好,麦克风哪个好,无线麦克风品牌推荐

​在自媒体日益繁荣的当下&#xff0c;内容创作成为了许多人追求的目标。对于视频内容创作者而言&#xff0c;出色的内容是成功的基石&#xff0c;而高质量的设备则是保证作品品质的关键。为了提升视频音质&#xff0c;拥有一款专业的无线麦克风是不可或缺的。 然而&#xff0…

PHP智能匹配轻松预订自习室在线订座系统小程序源码

智能匹配&#xff0c;轻松预订——自习室在线订座系统 &#x1f4da;【开篇&#xff1a;告别排队&#xff0c;迎接智能学习新时代】&#x1f4da; 还在为找不到合适的自习室座位而烦恼吗&#xff1f;是不是每次去图书馆或自习室都要提前好久去排队占位&#xff1f;现在&#…

太速科技-1路万兆光纤SFP+和1路千兆网络 FMC子卡模块

1路万兆光纤SFP和1路千兆网络 FMC子卡模块 一、概述 该板卡是基于kc705和ml605的fmc 10g万兆光纤扩展板设计&#xff0c;提供了1路万兆光纤SFP和1路千兆网络接口。可搭配我公司开发的FPGA载卡使用。载卡可参考&#xff1a;ID204 SFP&#xff08;10 Gigabit Small…

AWS-亚马逊网络服务(基础服务)-AWS 定价计算器-概述与动手部署:

让我们来概述并亲身实践如何使用 AWS 定价计算器来计算 概述&#xff1a; AWS 定价计算器是 Amazon Web Services (AWS) 提供的基于 Web 的工具&#xff0c;可帮助用户估算其特定用例的 AWS 服务成本。欢迎来到雲闪世界。 它允许客户建模他们的基础设施并根据他们打算使用的…

Android 9.0 增加interface audio接口,解决编译报错

最近修改Android接口&#xff0c;报了一个VNDK的错误 我总结了如下几种方式&#xff1a; 1、直接关闭&#xff08;不推荐&#xff09;&#xff1a; 在BoardConfig.mk中加入如下两行&#xff0c;可以在编译的时候不去check VNDK&#xff0c;关掉这个可能会导致XTS某些测项跑不…

Burp Suite Professional 2024.8 for macOS x64 ARM64 - 领先的 Web 渗透测试软件

Burp Suite Professional 2024.8 for macOS x64 & ARM64 - 领先的 Web 渗透测试软件 世界排名第一的 Web 渗透测试工具包 请访问原文链接&#xff1a;https://sysin.org/blog/burp-suite-pro-mac/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页…

Linux内核编程(十五)网络设备驱动

本文目录 一、常见的网络协议二、传输介质三、RJ-45接口 对于网络知识不太熟悉的同学可以查看这篇文章&#xff1a;计算机网络知识点详情总结。 一、常见的网络协议 TCP、UDP协议&#xff1a;详情查看-TCP、UDP系统编程。DNS协议&#xff1a;是互联网中用于将域名&#xff08…

RocketMQ集群搭建,及RocketMQ-Dashboard部署(前RocketMQ-Console)

集群搭建 RocketMQ不支持单主机搭建主从结构集群&#xff0c;当从节点启动时&#xff0c;即使和主节点设置不同的监听端口&#xff0c;他也要去监听主节点端口&#xff0c;也就是说正常启动的从节点会监听四个端口。原因未知&#xff0c;现象后面会列举出来。 1. 准备JAVA环境…

在 Ubuntu 环境下使用 VSCode 和 PlatformIO 下载程序到 Arduino Uno

安装 VSCode 访问 VSCode 官网 下载 .deb 包使用以下命令安装&#xff1a;sudo dpkg -i <下载的文件名>.deb sudo apt-get install -f安装 PlatformIO 扩展 在 VSCode 中&#xff0c;转到扩展市场&#xff08;CtrlShiftX&#xff09;搜索 “PlatformIO IDE”点击 “安装”…

STM32 HAL CAN (TJA1050CAN模块) 通讯(一)理论

1、简介 CAN具备多个设备交互的能力,但是网上大多是两个单片机进行交互,或者单片机通过CAN收发器与上位机进行交互测试,本次通过STM32cubeMX完成CAN通讯配置,并通过多个单片机进行数据交互测试。 2、CAN简介 CAN是一种串行通讯协议,主要有低速、高速CAN两种。 低速CAN…

相亲交友系统商业开发

在快节奏的现代生活中&#xff0c;寻找真爱成为了许多人的渴望。相亲交友系统&#xff0c;作为连接心灵的桥梁&#xff0c;正逐渐成为人们寻找伴侣的首选方式。我们的团队h17711347205致力于开发一款创新的相亲交友系统&#xff0c;旨在通过智能化的匹配算法&#xff0c;为用户…

Android UID 和 userID 以及 appID

我们知道Android 操作系统是基于Linux内核的&#xff0c;所以Android 的UID 是基于 Linux UID的。 Linux UID Linux 本身就是一个多用户操作系统&#xff0c;每一个用户都会有一个UID&#xff0c;不同UID 之间的资源访问是受限的。 其中&#xff0c;Linux的DAC权限模型&#…

【UE5】控件蓝图——树视图(TreeView)的基本使用

目录 前言 效果 步骤 一、显示根节点 二、显示子节点 前言 我们在视口中添加1个方块&#xff0c;2个球体&#xff0c;5个圆柱 它们在大纲视图中的层级关系如下&#xff0c;那么如何将这种层级关系显示在树视图中是本篇文章要解决的问题。 效果 步骤 一、显示根节点 1…

[STM32]从零开始的STM32标准库环境搭建(小白向)

一、我们为什么要搭建STM32标准库开发环境 如果你对STM32有一定的了解&#xff0c;相信你已经认识了STM32的几种开发方式。基于STM32寄存器开发&#xff0c;基于ST官方的标准库开发&#xff0c;基于ST官方的HAL库开发。我们现在来了解一下这些库的优缺点。首先就是基于寄存器开…

macos USB外接键盘ctrl键绑定方法 解决外接USB键盘与mac键盘不一致问题

mac电脑外接USB键盘后我们需要修改一下 ctrl键的绑定后才符合我们的使用习惯,因为标准USB键盘和mac键盘上面的ctrl键是不一样的, mac上面的 command 键 对应我们USB键盘上面的 ctrl 键. 修改方法: 偏好设置 --> 键盘 点击修饰键 后 选择键盘里面选择 USB键盘 ,然后调换…

Leetcode JAVA刷刷站(111)二叉树的最小深度

一、题目概述 二、思路方向 在Java中&#xff0c;要找出二叉树的最小深度&#xff0c;我们可以使用递归的方法。基本思路是&#xff0c;对于给定的根节点&#xff0c;如果它是空的&#xff0c;那么最小深度为0&#xff08;但实际上&#xff0c;空树没有深度&#xff0c;但在…

Sui Hacker House曼谷站报名开启:在Devcon 2024期间探索Sui区块链创新

Sui 曼谷 Hacker House 报名开启 Sui Bangkok Hacker House 将在曼谷于 2024 年 11 月 4 日至 17 日举办。诚邀开发者深入学习 Move 语言,在 Sui 网络上构建 MVP ,在充满活力的曼谷中度过难忘的两周。 诚挚地邀请开发者加入为期两周的 Sui Bangkok Hacker House。 你将与其他…