您当前的位置:首页 > 电脑百科 > 程序开发 > 架构

微服务开发和治理-如何屏蔽软件架构的复杂性

时间:2022-03-25 11:41:33  来源:  作者:人月聊IT
微服务开发和治理-如何屏蔽软件架构的复杂性

 

大家好,由于当前重心在知识分享视频的创作上面,因此减少了图文类文章的更新,但是对于一些关键点的思考仍然会更新图文,重点不在于长篇大论,而是将我的关键思考点讲清楚,内容不会再体现完整的体系化,而是类似经验点的分享。

什么意思呢?

就是我的文章你拿去转载没什么用,内容会很零星,但是这些思考点你沉下心来结合你自己的工作学习实践来阅读,还是会有帮助。

对于微服务,从基本概念到开发到治理,我在前面都谈过相当多的文章,今天谈这篇文章还是对于腾讯在北极星后又发布和开源了一个云原生标准的一站式微服务管理框架 Femas。感兴趣的大家可以去看下这篇文章。

微服务开发和治理-如何屏蔽软件架构的复杂性

 

https://www.infoq.cn/article/KksAEfXidiM2iwZMvZ0q

但是看了以后,发现这个平台更多还是应用到公有云,面对多租户的PaaS云原生平台中的微服务管控和治理上面。其本身强调了多种微服务开发框架,类似Dubbo,SpringCloud,gRPC的适配,多种服务注册中心,类似Eureka,Nacos,Consul的纳管和适配,多种微服务和API网关,多种可观测性开源组件的适配。

微服务开发和治理-如何屏蔽软件架构的复杂性

 

简单来说就是,不论你原来微服务开发采用的是什么开发框架和环境,微服务治理采用的是什么开源软件,都可以纳入到Femas进行统一的管理。

整个纳入管理的时候,又不需要对已有的微服务框架,微服务程序进行改动。

对于Femas本身也是基于ServiceMesh的思路,通过下放Sidecar边车代理的方式来实现各种适配能力,各种安全,日志,限流熔断,链路监控能力。

我在前面分享过一篇微软Dapr微服务框架的文章,参考:

微软开源Dapr微服务框架-云原生应用和微服务发展主流趋势

微服务开发和治理-如何屏蔽软件架构的复杂性

 

从Dapr的分层架构上,可以简单地理解为北向接口和能力开放,内部业务组件和逻辑实现,南向底层能力适配三个方面的内容。对于最上层的API层是最容易理解的,即将内部组件能力发布为API接口服务,既可以是Http Rest API接口,也可以是Rpc接口,而且可以做到灵活发布给前端应用使用。

对于Building Blocks,除了架构图里面谈到的状态管理,资源绑定,发布订阅,可观测性等能力外,更加重点是是和能力绑定在一起的核心业务组件和功能实现。也就是Building Blocks仅仅是核心组件逻辑实现附属的Sidecar能力。核心组件能力如何实现呢?你仍然可以按照传统的编程语言来实现你的核心业务规则和逻辑。

但是这个开源框架更多是站在公有云PaaS平台,面对多租户,多种异构微服务应用场景的时候适用。但是回到一个企业内部的IT应用开发,在微服务架构应用和选型的过程中,绝对不会说出现采用多种服务注册中心,多种网关,多种开发框架的问题。

那么企业级微服务开发者真正要解决的问题在哪里?

这个也是我强调的,对于企业内的微服务开发,应该是屏蔽微服务架构,开发框架,微服务后续治理和可观测性的诸多复杂性,真正让微服务开发尽量的简单和纯粹。

架构师应该做好这种屏蔽,不是说每个开发人员都需要去了解微服务底层框架技术原理,都需要去了解复杂的链路监控,限流熔断的实现。开发人员更多的重心是在功能的实现上,而不是微服务后续的管控治理。

微服务开发和微服务治理一定要分离。在微服务设计和开发过程中不应该引入任何的微服务治理内容。

先摘录一段内容:

基于传统组件面临的种种问题,Red Hat 首席架构师 Bilgin Ibryam 对云原生领域的微服务架构发展提出了 multi-runtime 的理念。runtime 作为理论的出发点,Bilgin Ibryam 提出现代分布式应用程序的需求分为 4 类,分别是生命周期(lifecycle)、网络.NETworking)、状态(state)和绑定(binding)。

  • 生命周期:编程语言会指定生态系统中的可用库、打包格式和运行时,自动化部署、弹性伸缩、自愈等代表了应用程序生命周期的需求。
  • 网络:从更广泛的角度去掌握网络,例如 DNS、流量管控。
  • 状态:依赖于底层的状态的分布式能力,如缓存、服务编排和工作流、分布式单例、临时调度。
  • 绑定:在跟外部系统的集成过程中,依赖于协议转化,错误恢复等能力。
微服务开发和治理-如何屏蔽软件架构的复杂性

 

如上面这个图。

简单理解就是我只想做好中间方块内容,实现相关的功能和API接口的开发。其它事情都不应该让开发人员操心。

而其他事情就包括了这个组件本身的生命周期和运行时管理(容器云集成),东西流量管理(服务注册发现),南北流量管控(微服务或API网关),可观测性(状态管理,链路监控),服务治理(安全,限流熔断,日志审计)等。

如果我是开发者我希望达到的一个目标就是方块外围的各种能力都不需要我在开发阶段去关心,都是应该在后续可以通过Sidecar边车代理的模式来灵活配置和实现。

我开发一个微服务,重点是实现业务功能,并且写好我的对外接口函数。

任何一个接口函数本身就应该具备多种接口协议的发布能力。举例来说如果是内部的各个微服务组件之间的调用,应该自动化的发布为TCP+RPC调用模式以提升接口性能。而对外发布才发布为Http Rest API接口以屏蔽防火墙影响等。

而这些开发人员也不需要关心,也需要做到可以灵活配置。

对于我开发自测通过的微服务,如果通过编译构建,打包,部署和最终交付到容器云平台,包括后续在容器云平台如何进行资源和状态的监控,组件资源的灵活动态调度,开发人员也不需要关心,微服务运行的全生命周期管理复杂性也不应该在开发态引入。

只有这样开发人员真正的重心才能够放在业务功能开发,业务逻辑的实现上面,而不是去关注微服务技术平台。

对于一个大企业也是同样的道理。

大企业本身也应该是平台+应用的构建模式,可以有独立的技术架构和平台组来辅助微服务开发框架,技术平台,治理平台的建设。而平台组提供给上层应用开发组的能力应该足够简单,不应该将微服务架构本身的一些复杂性引入到技术开发中。

不是每个开发人员都需要去详细了解微服务架构,开发框架,各种微服务治理技术组件和底层实现方案,更多的开发人员应该是使用微服务开发框架,开发过程应该足够简单,真正将重心放在业务和功能实现上。

这才是一个微服务架构设计的时候应该考虑的关键点。



Tags:软件架构   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
现代软件架构:事件驱动设计遇上事件溯源
在当今的软件领域中,做出正确的架构决策对于确保性能、可扩展性、可维护性和整体成功至关重要。在众多模式中,事件驱动架构(EDA)和事件溯源(ES)作为复杂软件系统最受欢迎的两种选...【详细内容】
2023-12-13  Search: 软件架构  点击:(114)  评论:(0)  加入收藏
2023软件架构和设计的趋势
2023年即将结束,值得回顾一下过去一年的软件架构和设计流行话题。在本文中,我们将讨论一些常见的软件架构和设计,根据InfoQ的报告,这些架构和设计被广泛采纳。我们主要关注创新...【详细内容】
2023-12-04  Search: 软件架构  点击:(132)  评论:(0)  加入收藏
CSaaS架构:数字孪生软件架构的革命性突破
BS(Browser/Server)和CS(Client/Server)是两种不同的软件架构模式,具有不同的特点和优缺点。BS(Browser/Server)架构BS架构指的是基于浏览器和服务器的软件架构,客户端通常是一个Web...【详细内容】
2023-10-20  Search: 软件架构  点击:(224)  评论:(0)  加入收藏
定义软件架构的四个维度是什么?
软件架构可以从以下四个维度进行定义:1. 结构维度:软件架构包括系统的结构,即系统中各个组件之间的关系和交互方式。这些组件可以是模块、服务、库或其他软件单元。结构维度关...【详细内容】
2023-10-18  Search: 软件架构  点击:(296)  评论:(0)  加入收藏
Linux NFSD软件架构与代码解析
在Linux操作系统发行版有一个NFS服务端,该服务端由内核态的模块和用户态的守护进程构成。其中内核态模块负责数据处理,而用户态守护进程则负责内核态的配置管理等功能。由于核...【详细内容】
2023-08-21  Search: 软件架构  点击:(210)  评论:(0)  加入收藏
三层软件架构导致程序员负担翻倍?
【CSDN 编者按】本文作者从工程师、技术领导者和开发人员角度,在发现自己身陷应用程序“管道”复杂性的困境之中,如何巧妙解决困境!原文链接:https://yrashk.medium.com/repeati...【详细内容】
2023-08-17  Search: 软件架构  点击:(329)  评论:(0)  加入收藏
聊聊【软件架构模式】—微内核架构
概述: 内核模式也被称为插件架构模式。 将附加应用程序功能作为插件添加到核心应用程序,以提供可扩展性以及功能分离和隔离。 这种模式由两种类型的架构组件组成:一个核心系统...【详细内容】
2023-06-20  Search: 软件架构  点击:(295)  评论:(0)  加入收藏
软件架构设计之构件与中间件技术
中间件的定义其实中间件是属于构件的一种。是一种独立的系统软件或服务程序,可以帮助分布式应用软件在不同技术之间共享资源。我们把它定性为一类系统软件,比如我们常说的消息...【详细内容】
2023-04-28  Search: 软件架构  点击:(413)  评论:(0)  加入收藏
软件架构设计之模型驱动架构MDA
概念模型驱动架构MDA, 全称叫做Model Driven Architecture。 Model:表示客观事物的抽象表示 Architecture:表示构成系统的部件,连接件及其约束的规约 Model Driven: 使用模型完...【详细内容】
2023-04-13  Search: 软件架构  点击:(289)  评论:(0)  加入收藏
软件架构设计:B/S层次架构之MVC/MVP/MVVM
层次架构风格从之前的两层C/S到三层C/S,然后演化为三层B/S架构,三层B/S架构之后仍然在往后面演化,我们来看一下层次架构演化过程中都有了哪些演化的架构风格呢?而我们先简单了解...【详细内容】
2023-04-11  Search: 软件架构  点击:(316)  评论:(0)  加入收藏
▌简易百科推荐
对于微服务架构监控应该遵守的原则
随着软件交付方式的变革,微服务架构的兴起使得软件开发变得更加快速和灵活。在这种情况下,监控系统成为了微服务控制系统的核心组成部分。随着软件的复杂性不断增加,了解系统的...【详细内容】
2024-04-03  步步运维步步坑    Tags:架构   点击:(7)  评论:(0)  加入收藏
大模型应用的 10 种架构模式
作者 | 曹洪伟在塑造新领域的过程中,我们往往依赖于一些经过实践验证的策略、方法和模式。这种观念对于软件工程领域的专业人士来说,已经司空见惯,设计模式已成为程序员们的重...【详细内容】
2024-03-27    InfoQ  Tags:架构模式   点击:(17)  评论:(0)  加入收藏
哈啰云原生架构落地实践
一、弹性伸缩技术实践1.全网容器化后一线研发的使用问题全网容器化后一线研发会面临一系列使用问题,包括时机、容量、效率和成本问题,弹性伸缩是云原生容器化后的必然技术选择...【详细内容】
2024-03-27  哈啰技术  微信公众号  Tags:架构   点击:(13)  评论:(0)  加入收藏
DDD 与 CQRS 才是黄金组合
在日常工作中,你是否也遇到过下面几种情况: 使用一个已有接口进行业务开发,上线后出现严重的性能问题,被老板当众质疑:“你为什么不使用缓存接口,这个接口全部走数据库,这怎么能扛...【详细内容】
2024-03-27  dbaplus社群    Tags:DDD   点击:(15)  评论:(0)  加入收藏
高并发架构设计(三大利器:缓存、限流和降级)
软件系统有三个追求:高性能、高并发、高可用,俗称三高。本篇讨论高并发,从高并发是什么到高并发应对的策略、缓存、限流、降级等。引言1.高并发背景互联网行业迅速发展,用户量剧...【详细内容】
2024-03-13    阿里云开发者  Tags:高并发   点击:(9)  评论:(0)  加入收藏
如何判断架构设计的优劣?
架构设计的基本准则是非常重要的,它们指导着我们如何构建可靠、可维护、可测试的系统。下面是这些准则的转换表达方式:简单即美(KISS):KISS原则的核心思想是保持简单。在设计系统...【详细内容】
2024-02-20  二进制跳动  微信公众号  Tags:架构设计   点击:(40)  评论:(0)  加入收藏
详解基于SpringBoot的WebSocket应用开发
在现代Web应用中,实时交互和数据推送的需求日益增长。WebSocket协议作为一种全双工通信协议,允许服务端与客户端之间建立持久性的连接,实现实时、双向的数据传输,极大地提升了用...【详细内容】
2024-01-30  ijunfu  今日头条  Tags:SpringBoot   点击:(21)  评论:(0)  加入收藏
PHP+Go 开发仿简书,实战高并发高可用微服务架构
来百度APP畅享高清图片//下栽のke:chaoxingit.com/2105/PHP和Go语言结合,可以开发出高效且稳定的仿简书应用。在实现高并发和高可用微服务架构时,我们可以采用一些关键技术。首...【详细内容】
2024-01-14  547蓝色星球    Tags:架构   点击:(122)  评论:(0)  加入收藏
GraalVM与Spring Boot 3.0:加速应用性能的完美融合
在2023年,SpringBoot3.0的发布标志着Spring框架对GraalVM的全面支持,这一支持是对Spring技术栈的重要补充。GraalVM是一个高性能的多语言虚拟机,它提供了Ahead-of-Time(AOT)编...【详细内容】
2024-01-11    王建立  Tags:Spring Boot   点击:(131)  评论:(0)  加入收藏
Spring Boot虚拟线程的性能还不如Webflux?
早上看到一篇关于Spring Boot虚拟线程和Webflux性能对比的文章,觉得还不错。内容较长,抓重点给大家介绍一下这篇文章的核心内容,方便大家快速阅读。测试场景作者采用了一个尽可...【详细内容】
2024-01-10  互联网架构小马哥    Tags:Spring Boot   点击:(129)  评论:(0)  加入收藏
站内最新
站内热门
站内头条