其他分享
首页 > 其他分享> > 手把手教你学Dapr - 1. .Net开发者的大时代

手把手教你学Dapr - 1. .Net开发者的大时代

作者:互联网

Dapr全称

Distributed Application Runtime,分布式应用运行时

Dapr的口号

简化云原生应用开发,聚焦在应用的核心逻辑,让代码简单、可移植

Dapr的目标

  1. 最佳实践的构建块
  2. 任何语言或框架
  3. 一致性,可移植,开放的API
  4. 采纳标准
  5. 可扩展和可插拔的组件
  6. 与平台无关(本地,云计算,边缘计算等)
  7. 社区驱动,供应商(厂商)中立
    dapr_goals.png

Dapr的设计思路

这里首先要先理解几个问题,然后再看Dapr如何解决这些问题的

以下资料都有英文原图,中文翻译为个人理解,英文好的小伙伴可以直接看原图。

微服务为什么很难

  1. 开发者要构建自己的运行时处理分布式应用问题
  2. 运行时支持的开发语言有限,且有严格控制的特性(功能)集合
  3. 运行时的可移植性有限,一般只支持特定的基础架构平台

what_is_holding_back_microservice_development.png

分布式应用的需求

内容引自 Multi-Runtime Microservices Architecture https://www.infoq.com/articles/multi-runtime-microservice-architecture/

注意:二级内容不与图片对应,把功能组合成场景

distributed_app.png

传统中间件和云原生对比

传统中间件以各种SDK的方式提供能力,而云原生平台则通过各种外围的Runtime,目前来看比较有趣的是,大家不约而同的选择了Sidecar。

future_architecture_trends.png

多运行时微服务边界

multi-runtime_microservices_boundary.png

多运行时的好处

业务逻辑和不断增加的分布式系统关注点之间的松耦合。

业务逻辑经常变化,取决于业务优先级。

而分布式原语则由软件供应商提供,作为库、容器、服务来使用。这些代码会根据供应商优先级、发布周期、安全补丁、开源治理规则等而变化。

他们互相看不到对方,也无法控制对方。

architecture_benefits.png

Dapr的优势:Any language, anywhere

与语言无关,与平台无关

image

分布式应用运行时

官方解释

帮助开发人员构建事件驱动的、弹性的分布式应用程序。 无论是在本地、云中还是在边缘设备上,都可以帮助你解决构建微服务所带来的挑战,并保持代码与平台无关。

可以看到Dapr更具象化了

  1. 与应用程序通过HTTP和gRPC通信
  2. 内部有一些构建块
  3. 运行在云上

dapr.png

Dapr与服务网格

dapr_and_servicemesh.png

Sidecar的世界

  1. 应用于Sidecar通信是通过Dapr API(已经被封装成不同开发语言的SDK),这个过程中通过OpenTelemetry支持了可观测性(即跟踪、日志、指标)
  2. 应用之间通过Sidecar通信,支持mTLS,这个指服务调用(即Service Invocation)
  3. Sidecar 之间通过gRPC(图片中没有显示),Bindings,Pub/Sub都可以通信
  4. 可观测性无处不在,通过Prometheus、Zipkin、Fluentd等,可视化OpenTelemetry中的部分数据

但目前据我所知没有一个可以统一接管完整OpenTelemetry的,如果有的话欢迎纠错。

  1. 状态管理也是由Sidecar代理的

sidecar_components.png

对于.Net的意义

我们正在行动,新的框架、新的生态

我们的目标是自由的易用的可塑性强的功能丰富的健壮的

所以我们借鉴Building blocks的设计理念,正在做一个新的框架MASA Framework,它有哪些特点呢?

经过几个月的生产项目实践,已完成POC,目前正在把之前的积累重构到新的开源项目中

目前源码已开始同步到Github(文档站点在规划中,会慢慢完善起来):

MASA.BuildingBlocks

MASA.Contrib

MASA.Utils

MASA.EShop

BlazorComponent

MASA.Blazor

QQ群:7424099

微信群:加技术运营微信(MasaStackTechOps),备注来意,邀请进群

标签:MASA,手把手,分布式应用,Dapr,运行,Net,Sidecar
来源: https://www.cnblogs.com/doddgu/p/dapr-learning-1.html