1.概述
想要对.net的微服务方案进行一下调查,看有什么可选的方案和框架,与spring clound相比.net 创建微服务是相对较麻烦的。
ID | 名称 | 说明 |
1 | Service Fabric | Steeltoe是帮助.NET开发的服务接入Spring Cloud技术栈的官方支持工具。也就是说,微服务的系统框架,还是由Spring Cloud来实现,而业务服务,通过.NET Core来实现。 |
2 | Dapr | Dapr(Distributed Application Runtime) 是微软于 2019 年 10 月 16 日 首次发布[1] 的分布式程序运行时 |
3 | Steeltoe | Steeltoe 是一个 .NET 微服务框架,它是 Spring Cloud 的 .NET 版本。它提供了一种在 .NET 平台上实现微服务架构的方式,同时提供了对常用云服务的集成,如 Netflix Eureka、Spring Cloud Config 和 Zipkin。Steeltoe 还支持在 .NET Core 和 .NET Framework 上运行。 |
3 | MASA Framework | 是.NET的下一代微服务开发框架,提供了基于Dapr的云原生最佳实践,能够快速实现分布式、微服务、DDD,SaaS等现代应用开发。是国产微服务框架。 |
EEEEsEEEE
2.详细
2.1 Service Fabric
简介:
Service Fabric 是一个微服务框架,它由微软开发并托管在 Azure 上。它提供了一种分布式系统的方式,允许开发人员在云、本地和边缘环境中构建高可用性、可扩展的服务。Service Fabric 支持多种语言和平台,如 .NET、Java、Node.js 和 Docker。
特征:
1、可扩展性和高可用性
Service Fabric是为构建可扩展、高可用性和可靠的分布式系统而设计的。它提供了自动化容错、负载均衡、故障转移和自动缩放等功能,可以帮助应用程序处理大量请求,并能够根据需求自动调整资源。
2、支持多种编程语言和平台
Service Fabric支持多种编程语言和平台,包括.NET、Java、Node.js、Python和C++等。开发人员可以使用他们熟悉的编程语言和框架来开发微服务应用程序。
3、灵活的部署选项
Service Fabric提供了多种部署选项,包括在云、本地和边缘环境中运行应用程序。它还支持容器化应用程序,可以帮助开发人员在不同的平台和环境中轻松部署应用程序。
4、内置的监控和诊断工具
Service Fabric提供了内置的监控和诊断工具,可以帮助开发人员快速识别和解决应用程序中的问题。它提供了实时指标、日志记录、故障分析和自动缩放等功能,可以帮助开发人员了解应用程序的状态和性能。
5、适用于大规模系统
Service Fabric是为构建大规模分布式系统而设计的。它可以处理数千个节点和数百万个容器的大型系统,并具有高可用性和可靠性。
二、Dapr
简介:
Dapr(Distributed Application Runtime)是一个跨语言、开源的微服务框架,它可以在任何地方运行,无论是云、边缘还是本地环境。Dapr 提供了一组可插拔的构建块和 API,用于处理常见的微服务任务,如状态管理、消息传递、服务发现、故障转移和安全性。
特征:
1、语言无关性
Dapr是与语言无关的,可以与任何编程语言和框架一起使用。它提供了与语言无关的API和SDK,可以让开发人员使用自己熟悉的编程语言和框架来构建微服务应用程序。
2、通用构建块
Dapr提供了一组通用的构建块,包括状态管理、消息传递、事件处理、服务调用和密码管理等。这些构建块可以轻松地集成到微服务应用程序中,让开发人员专注于业务逻辑的实现,而不用担心底层的复杂性。
3、可插拔性
Dapr是可插拔的,可以与任何基础设施和服务一起使用。它提供了与Kubernetes、Azure、AWS、GCP和Consul等平台和服务的集成,可以帮助开发人员轻松地在不同的环境中部署应用程序。
4、安全性
Dapr提供了一组安全性特性,包括加密、认证和授权等。它还提供了安全性的最佳实践,可以帮助开发人员构建安全的微服务应用程序。
5、开源
Dapr是一个完全开源的微服务框架,由Microsoft、Alibaba和其他公司共同开发和维护。它的代码托管在GitHub上,并且拥有一个活跃的社区,可以帮助开发人员解决问题和提供反馈。
三、Steeltoe
简介:
Steeltoe 是一个 .NET 微服务框架,它是 Spring Cloud 的 .NET 版本。它提供了一种在 .NET 平台上实现微服务架构的方式,同时提供了对常用云服务的集成,如 Netflix Eureka、Spring Cloud Config 和 Zipkin。Steeltoe 还支持在 .NET Core 和 .NET Framework 上运行。
特征:
1、云原生应用支持
Steeltoe提供了一组用于构建云原生应用程序的工具和库,可以轻松地在.NET应用程序中集成云服务,如服务发现、负载均衡、配置管理、追踪和监控等。这些工具和库与Spring Cloud、Netflix OSS和HashiCorp Consul等云原生应用程序框架兼容。
2、可插拔性
Steeltoe是可插拔的,可以与任何.NET应用程序一起使用。它提供了一组通用的构建块,包括服务发现、负载均衡、配置管理和追踪等。这些构建块可以轻松地集成到.NET应用程序中,让开发人员专注于业务逻辑的实现,而不用担心底层的复杂性。
3、安全性
Steeltoe提供了一组安全性特性,包括加密、认证和授权等。它还提供了安全性的最佳实践,可以帮助开发人员构建安全的.NET应用程序。
4、开源
Steeltoe是一个完全开源的.NET微服务框架,由Pivotal公司开发和维护。它的代码托管在GitHub上,并且拥有一个活跃的社区,可以帮助开发人员解决问题和提供反馈。
四、MASA Framework
简介:
是.NET的下一代微服务开发框架,提供了基于Dapr的云原生最佳实践,能够快速实现分布式、微服务、DDD,SaaS等现代应用开发。是国产微服务框架。
特征:
1、原生支持Dapr
原生支持Dapr,且允许将Dapr替换成传统通信方式
2、架构不限,单体应用、SOA、微服务都支持
3、学习成本低
支持.Net原生框架,降低学习负担,除特定领域必须引入的概念,坚持不造新轮子
4、生态丰富
丰富的生态支持,除了框架以外还有组件库、权限中心、配置中心、故障排查中心、报警中心等一系列产品
3.引用链接
3.1 Service Fabric
Service Fabric 基础结构服务简介 - Azure Service Fabric | Microsoft Learn
Service Fabric首页、文档和下载 - 微软的分布式系统平台 - OSCHINA - 中文开源技术交流社区
3.2 Dapr
https://www.cnblogs.com/codechange/p/17104572.html
下一代微服务框架 Dapr 中文入门指南-CSDN博客
3.3 Steeltoe
https://www.cnblogs.com/wswind/p/12436081.html
.NET构建云原生微服务的框架Steeltoe-CSDN博客
3.4 MASA Framework
.NET微服务架构及API网关 - 知乎
4 其他链接
.NET 微服务。 适用于容器化 .NET 应用程序的体系结构 | Microsoft Learn