微服务架构2.0--云原生时代

news2024/10/1 21:39:02

云原生

云原生(Cloud Native)是一种关注于在云环境中构建、部署和管理应用程序的方法和理念。云原生应用能够最大程度地利用云计算基础设施的优势,如弹性、自动化、可伸缩性和高可用性。这个概念涵盖了许多方面,包括架构、开发、部署、运维和团队文化等

云原生特点和原则

  1. 容器化: 将应用及其依赖打包为容器,以实现一致性的运行环境。容器技术如Docker提供了隔离性、可移植性和快速部署的优势。
  2. 微服务架构: 将应用拆分为小型、独立的服务单元,每个单元专注于特定的业务功能。这提高了可维护性、可扩展性和敏捷性。
  3. 自动化: 强调自动化的开发、测试、部署和运维流程,包括持续集成、持续交付、自动扩展等,以提高效率和稳定性。
  4. 灵活性: 云原生应用通过微服务架构和容器化,使得每个服务单元可以独立开发、部署和扩展,增强了应对变化的能力。
  5. 弹性: 云原生应用能够根据负载自动扩展和缩减,以应对流量的变化。
  6. 服务治理: 强调服务的发现、负载均衡、流量管理以及容错机制,以确保服务的可靠通信。
  7. 声明式API和基础设施即代码: 通过声明式API和基础设施即代码的方式,实现应用的自动化部署和管理。
  8. 可观测性: 强调应用的监控、日志、追踪和指标,以便及时发现和解决问题。
  9. 开放性和多样性: 云原生技术不限于特定的语言、框架或云平台,鼓励采用开放标准和多样的技术栈。

云原生是一个综合性的概念,旨在使应用能够更好地利用云计算的优势,提供更高的可靠性、可扩展性和敏捷性容器化、微服务、自动化和弹性等原则是实现云原生应用的关键。

分布式系统固有问题

在微服务架构中,会面临一些必须解决的问题,比如注册发现、跟踪治理、负载均衡、传输通讯等。只要是分布式系统,就没办法完全避免这些问题,回过头来想一下:这些问题一定要由分布式系统自己来解决吗?

1、SpringCloud与Kubernetes

同一个分布式服务的问题,对比下 Spring Cloud 中提供的应用层面的解决方案,以及 Kubernetes 中提供的基础设施层面的解决方案
在这里插入图片描述
虽然 Spring Cloud 和 Kubernetes 的出发点不同,解决问题的方法和效果也不一样,但不容忽视的是,Kubernetes 的确提供了一条全新的、前途更加广阔的解题思路。

与业务无关的技术问题,便很可能从软件的层面剥离出来,在硬件的基础设施之内就被悄悄解决掉,让软件可以只专注于业务,真正“围绕业务能力构建”团队与产品。

那么原来只能从软件层面解决的分布式架构问题,于是有了另外一种解法:应用代码与基础设施软硬一体,合力应对。

Kubernetes的局限性
基础设施是针对整个容器来做整体管理的,它的粒度就相对粗犷。
有一些问题处于应用系统与基础设施的边缘,Kubernetes很难能完全在基础设施的层面中,去精细化地解决掉它们。

  1. 业务逻辑和基础设施的关系: 某些问题可能与特定的业务逻辑紧密相关,难以通过通用的基础设施解决。在这种情况下,微服务框架(如 Spring
    Cloud)可能更容易为业务提供定制化的解决方案。
  2. 微服务治理和业务规则: 一些问题涉及到业务规则和治理的结合,这可能需要更高层次的抽象和定制化。
  3. 业务复杂性: 对于某些复杂的业务流程,特定的定制化解决方案可能更适合,而通用的基础设施(如 Kubernetes)可能需要更多的适配。

2、服务网格(Service Mesh)与Sidecar Proxy

服务网格(Service Mesh)是一种用于管理和监控微服务架构中服务之间通信的基础设施层。它提供了一系列的工具和功能,以解决微服务架构中的一些共性问题,如服务发现、负载均衡、安全性、故障处理等。

**Sidecar Proxy(**边车代理)是一种在微服务架构中用于处理服务之间通信的模式。它将通信逻辑从应用程序代码中分离出来,作为一个单独的代理进程(sidecar)运行在同一容器、同一主机或同一虚拟机上,与主应用程序共同工作,处理诸如路由、负载均衡、安全性、监控等通信相关的任务。

边车代理主要使用场景

  1. 服务发现和负载均衡: 边车代理可以负责服务发现并在服务之间实施负载均衡,将请求动态分配给不同的服务实例。
  2. 安全性: 边车代理可以提供安全性功能,如认证、授权、加密等,确保只有授权的服务可以通信。
  3. 监控和跟踪: 边车代理可以收集和记录请求和响应数据,以便进行监控和跟踪,帮助分析和解决问题。
  4. 重试和超时: 边车代理可以处理请求的重试和超时,确保请求在一定时间内得到响应。
  5. 熔断和断路器: 边车代理可以实施熔断和断路器机制,当某个服务出现故障时,停止向其发送请求,以避免影响整个系统。
  6. 路由和流量控制: 边车代理可以实现流量的控制和路由策略,用于实现灰度发布、A/B测试等功能。
  7. 请求转换和响应加工: 边车代理可以对请求和响应进行转换和加工,实现协议转换、数据格式转换等。

边车代理优势

  1. 解耦通信逻辑: 服务网格将通信逻辑从应用程序中解耦,使开发人员可以专注于业务逻辑的开发,而不必担心通信细节。
  2. 可观察性: 服务网格通常提供丰富的监控、跟踪和日志功能,帮助开发人员和运维团队更好地了解和管理服务之间的通信。
  3. 流量管理: 服务网格允许对流量进行精细的控制,包括流量分流、A/B 测试、灰度发布等,从而提供更大的灵活性。
  4. 安全性: 服务网格可以提供安全功能,如认证、授权、加密等,确保服务之间的通信是安全的。
  5. 故障恢复: 服务网格可以处理故障检测和恢复,当某个服务实例失败时,可以自动切换到其他健康的实例。
  6. 跨语言支持: 服务网格通常支持多种编程语言和技术栈,适用于多样化的微服务生态系统。

边车代理成本

  1. 复杂性: 引入服务网格会增加系统的复杂性,特别是在小规模项目中可能会显得过度。
  2. 性能开销: 由于服务网格的代理需要处理通信逻辑,可能会引入一定的性能开销,尤其在高吞吐量的场景中。
  3. 学习曲线: 学习和部署服务网格需要时间,开发团队需要熟悉其概念和配置。
  4. 维护: 服务网格的部署和维护可能需要额外的工作,特别是在涉及多个服务的复杂环境中。
  5. 适用性: 并非所有微服务架构都需要服务网格,一些简单的场景可能不需要引入这种复杂的通信层。

常见的边车代理

Envoy: 由CNCF(Cloud Native Computing Foundation)维护的开源代理,具有强大的路由、负载均衡、故障恢复等功能。

Istio: 是一个由Google、IBM和Lyft共同开源的服务网格平台,旨在简化和改进微服务架构中服务之间的通信、管理和监控。Istio 提供了一系列功能和工具,用于解决微服务架构中的一些通用问题,如流量管理、故障恢复、安全性和可观察性等。

服务网格将会成为微服务之间通讯交互的主流模式,它会把“选择什么通讯协议”“如何做认证授权”之类的技术问题隔离于应用软件之外,取代今天的 Spring Cloud 全家桶中的大部分组件的功能。

软件架构演进方向

让开发人员专注于业务逻辑,将与业务无关的技术问题从软件层面剥离出来”,并通过基础设施和工具来处理这些技术问题。这有助于提高开发效率、降低维护成本,并使开发团队能够更专注于核心业务功能的创新。

业务与技术完全分离,远程与本地完全透明,也许这就是分布式架构最好的时代。

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

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

相关文章

DataLoader

机器学习的五个步骤: 数据模块——模型——损失函数——优化器——训练 在实际项目中,如果数据量很大,考虑到内存有限、I/O 速度等问题,在训练过程中不可能一次性的将所有数据全部加载到内存中,也不能只用一个进程去加…

mmdetection基于 PyTorch 的目标检测开源工具箱 入门教程

安装环境 MMDetection 支持在 Linux,Windows 和 macOS 上运行。它需要 Python 3.7 以上,CUDA 9.2 以上和 PyTorch 1.8 及其以上。 1、安装依赖 步骤 0. 从官方网站下载并安装 Miniconda。 步骤 1. 创建并激活一个 conda 环境。 conda create --name…

厦门逗客传媒:抖音本地团购怎么入驻

随着社交媒体的不断发展,短视频平台已经成为了商家推广和营销的热门渠道之一。在这其中,抖音作为全球知名的短视频平台,以其巨大的用户基数和精准的推荐算法吸引了大量商家的关注。而在抖音上,本地团购也成为了一个备受关注的领域…

控制Unity发布的PC包的窗体

大家好,我是阿赵。   用Unity发布PC包接入某些渠道时,有时候会收到一些特殊的需求,比如控制窗口最大化(比如某些情况强制显示窗体)、最小化(比如老板键)、强制规定窗体置顶等。虽然我一直认为这些需求都是流氓软件行为,但作为一…

【每日易题】七夕限定——单身狗问题以及进阶问题位运算法的深入探讨

君兮_的个人主页 勤时当勉励 岁月不待人 C/C 游戏开发 Hello,米娜桑们,这里是君兮_,在写这篇博客的前一天是七夕,也是中国传统的“情人节”,不知道各位脱单了吗?碰巧最近刷题时遇到了经典的单身狗问题想带大家深入探…

消息队列前世今生 字节跳动 Kafka #创作活动

消息队列前世今生 1.1 案例一: 系统崩溃 首先大家跟着我想象一下下面的这个的场景, 看到新出的游戏机,太贵了买不起,这个时候你突然想到,今天抖音直播搞活动,打开抖音搜索,找到直播间以后&am…

JVM——类加载与字节码技术—编译期处理+类加载阶段

3.编译期处理 编译期优化称为语法糖 3.1 默认构造器 3.2 自动拆装箱 java基本类型和包装类型之间的自动转换。 3.3泛型集合取值 在字节码中可以看见,泛型擦除就是字节码中的执行代码不区分是String还是Integer了,统一用Object. 对于取出的Object&…

【ARM】Day9 cortex-A7核I2C实验(采集温湿度)

1. 2、编写IIC协议,采集温湿度值 iic.h #ifndef __IIC_H__ #define __IIC_H__ #include "stm32mp1xx_gpio.h" #include "stm32mp1xx_rcc.h" #include "led.h" /* 通过程序模拟实现I2C总线的时序和协议* GPIOF ---> AHB4* I2C1_S…

IoT DC3 是一个基于 Spring Cloud 的开源的、分布式的物联网(IoT)平台本地部署步骤

dc3 windows 本地搭建步骤: ​​ 必要软件环境 进入原网页# 务必保证至少需要给 docker 分配:1 核 CPU 以及 4G 以上的运行内存! JDK : 推荐使用 Oracle JDK 1.8 或者 OpenJDK8,理论来说其他版本也行; Maven : 推荐…

记录《现有docker中安装spark3.4.1》

基础docker环境中存储hadoop3--方便后续查看 参考: 实践: export JAVA_HOME/opt/apache/jdk1.8.0_333 export SPARK_MASTER_IP192.168.0.220 export SPARK_WORKER_MEMORY4g export SPARK_WORKER_CORES2 export SPARK_EXECUTOR_MEMORY4g export HADOOP_H…

『SEQ日志』在 .NET中快速集成轻量级的分布式日志平台

📣读完这篇文章里你能收获到 如何在Docker中部署 SEQ:介绍了如何创建和运行 SEQ 容器,给出了详细的执行操作如何使用 NLog 接入 .NET Core 应用程序的日志:详细介绍了 NLog 和 NLog.Seq 来配置和记录日志的步骤日志记录示例&…

微服务中间件--MQ

MQ MQa.安装RabbitMQb.消息模型c.SpringAMQP发送和接收d.WorkQueue模型e.发布订阅模型1) FanoutExchange2) DirectExchange3) TopicExchange f.消息转换器 MQ 同步调用的问题 微服务间基于Feign的调用就属于同步方式,存在一些问题。 耦合度高:每次加入…

【网络安全】防火墙知识点全面图解(二)

本系列文章包含: 【网络安全】防火墙知识点全面图解(一)【网络安全】防火墙知识点全面图解(二) 防火墙知识点全面图解(二) 21、路由器的访问控制列表是什么样的?22、防火墙的安全策…

java电子病历源码 电子病历编辑器源码 病历在线制作、管理和使用

电子病历在线制作、管理和使用的一体化电子病历解决方案,通过一体化的设计,提供对住院病人的电子病历书写、保存、修改、打印等功能。电子病历系统将临床医护需要的诊疗资料以符合临床思维的方法展示。建立以病人为中心,以临床诊疗信息为主线…

【WebSocket】前端使用WebSocket实时通信

目录 前言什么是WebSocketWebSocket的工作原理WebSocket与HTTP的关系HTTP建立持久化连接WebSocket类封装 前言 最近写项目,需要实现消息通知和实时聊天的功能,就去了解了一些关于websocket的知识,总结如下。 什么是WebSocket WebSocket 是一…

Prometheus 监控系统

常用的监控系统有哪些? 老牌传统 Zabbix Nagios Cacti 新一代的 Prometheus 夜莺 Zabbix 和 Prometheus 的区别?如何选择?【重中之重】 Zabbix 更适用于传统业务架构的物理机、虚拟机环境的监控,对容器环境的支持较差&#xf…

5.从头跑一个pipeline

1.安装torch pip install torchvision torch PyTorch的torchvision.models模块中自带的很多预定义模型。torchvision 是PyTorch的一个官方库,专门用于处理计算机视觉任务。在这个库中,可以找到许多常用的卷积神经网络模型,包括ResNet、VGG、…

【Eclipse】汉化简体中文教程(官方汉化包,IDE自带软件安装功能),图文详情

目录 0.环境 1.步骤 1)查看eclipse的版本 2)在官网找语言包,并复制链接 3)将链接复制到eclipse中 4)汉化完成 0.环境 windows11,64位; eclipse 2021-6版本 1.步骤 思路:在官网找…

【FAQ】云存储EasyCVR视频汇聚平台分发rtsp流时,出现“用户已过期”提示该如何解决?

视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同,支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。音视频流媒体视频平台EasyCVR拓展性强,视频能力丰富,具体可实现视频监控直播、视频轮播、视频录像、…