.NET有哪些微服务框架

1.概述

想要对.net的微服务方案进行一下调查,看有什么可选的方案和框架,与spring clound相比.net 创建微服务是相对较麻烦的。

ID名称说明
1Service FabricSteeltoe是帮助.NET开发的服务接入Spring Cloud技术栈的官方支持工具。也就是说,微服务的系统框架,还是由Spring Cloud来实现,而业务服务,通过.NET Core来实现。
2DaprDapr(Distributed Application Runtime) 是微软于 2019 年 10 月 16 日 首次发布[1] 的分布式程序运行时
3SteeltoeSteeltoe 是一个 .NET 微服务框架,它是 Spring Cloud 的 .NET 版本。它提供了一种在 .NET 平台上实现微服务架构的方式,同时提供了对常用云服务的集成,如 Netflix Eureka、Spring Cloud Config 和 Zipkin。Steeltoe 还支持在 .NET Core 和 .NET Framework 上运行。
3MASA 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

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

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

相关文章

STM32F1 - I2C读写EEPROM

Inter-integrated circuit 1> 实验概述2> I2C模块 - 硬件方框图3> I2C模块 - 主发送器模式4> I2C模块 - 主接收器模式 1> 实验概述 通过STM32F103内部I2C硬件模块, 读写EEPROM - AT24C02 2> I2C模块 - 硬件方框图 3> I2C模块 - 主发送器模式 4…

GPT-4助力我们突破思维定势

GPT-4在突破思维局限、激发灵感和促进知识交叉融合方面的作用不可小觑,它正逐渐成为一种有力的工具,助力各行业和研究领域的创新与发展。 GPT-4在突破传统思维模式、拓宽创新视野和促进跨学科知识融合方面扮演着越来越重要的角色: 突破思维…

【Oracle11g安装配置详细教程——详细讲解】

Oracle11g安装配置详细教程 1. 介绍2. Windows环境安装Oracle 11g步骤3. Linux环境安装Oracle 11g步骤4. 注意事项 1. 介绍 由于Oracle 11g的安装涉及到一系列复杂的步骤,并且每一步可能还会因为操作系统的不同(如Windows、Linux)而略有差异…

java 数据结构LinkedList类

目录 什么是LinkedList 链表的概念及结构 链表的结构 无头单向非循环链表 addFirst方法(头插法) addLast方法(尾插法) addIndex方法 contains方法 removeAllKey方法 size和clear方法 链表oj题 无头双向非循环链表 ad…

Paper - 使用 CombFold 组合装配实现大型蛋白质复合物的结构预测

欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://spike.blog.csdn.net/article/details/136170304 CombFold: predicting structures of large protein assemblies using a combinatorial assembly algorithm and AlphaFold2 CombFold…

大公司为什么禁止SpringBoot项目使用Tomcat?

原作者:老杨 原文PDF链接:https://topjavaer.cn/advance/excellent-article/28-springboot-forbid-tomcat.html 前言 在SpringBoot框架中,我们使用最多的是Tomcat,这是SpringBoot默认的容器技术,而且是内嵌式的Tomcat…

ClickHouse监控及备份

第1章 ClickHouse监控概述 第2章 Prometheus&Grafana的安装 第3章 ClickHouse配置 第4章 Grafana集成Prometheus 第5章 备份及恢复

【C语言】位操作符与移位操作符练习

目录 前言: 1.一道变态的面试题 2.输入一个整数 n ,输出该数32位二进制表示中1的个数。其中负数用补码表示。 方法一: 方法二: 方法三: 3.打印整数二进制的奇数位和偶数位 前言: 前篇我们学习过C语言…

【开源】JAVA+Vue.js实现城市桥梁道路管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块三、系统展示四、核心代码4.1 查询城市桥梁4.2 新增城市桥梁4.3 编辑城市桥梁4.4 删除城市桥梁4.5 查询单个城市桥梁 五、免责说明 一、摘要 1.1 项目介绍 基于VueSpringBootMySQL的城市桥梁道路管理系统,支持…

gem5学习(22):经典内存系统的一致性——Classic Memory System coherence

官网教程:gem5: Classic memory system coherence M5 2.0b4引入了一个经过大量重写和简化的缓存模型,包括一个新的一致性协议。一致性协议是用于确保多个缓存之间的数据一致性的规则和机制。这意味着在多个缓存中存储的数据将保持一致,以避免…

C#分部类、分割类的用法,及用分割类设计一个计算器

目录 一、涉及到的知识点 1.分部类 2.分部类主要应用在以下两个方面 3.合理使用分部类分割类 4.事件处理程序 5.Math.Ceiling方法 6.Text.Contains() 7.pictureBox.Tag属性 二、实例 1.源码 2.生成效果 在开发一些大型项目或者特殊部署时,可能需要…

MySQL的基础架构

文章目录 前言MySQL的基础架构总结 前言 你使用 MySQL 开发,你知道 MySQL 的基础架构吗?本文带你来入门MySQL 的基础架构 MySQL的基础架构 MySQL 是我们经常使用到的数据库。它的基础架构分为 server 层与存储引擎层。 server 层:用于存储…

(十九)springboot实战——springboot集成redis实现消息的订阅与发布

前言 本节内容主要介绍springboot项目通过集成redis,如何利用redis的订阅发布机制,完成系统消息的发布与订阅功能。Redis中的发布与订阅是一种消息通信模式,允许发送者(发布者)将消息发送给多个接收者(订…

小型医院医疗设备管理系统|基于springboot小型医院医疗设备管理系统设计与实现(源码+数据库+文档)

小型医院医疗设备管理系统目录 目录 基于springboot小型医院医疗设备管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、职员信息管理 2、设备信息管理 3、库房信息管理 4、公告信息管理 四、数据库设计 1、实体ER图 五、核心代码 六、论文参考 七、…

2.15日学习打卡----初学Zookeeper(二)

2.15日学习打卡 目录: 2.15日学习打卡一. Zookeeper部署运行伪集群安装集群安装服务管理 二. Zookeeper系统模型数据模型节点特性客户端命令行节点数据信息Watcher监听机制权限控制 ACL 三. 原生api操作Zookeeper四. zkclient库操作Zookeeper五. Apache Curator操作Zookeeper六…

Kubernetes基础(十八)-k8s存储对象Persistent Volume

1 什么是Persistent Volume? 在容器化应用中,Pod的生命周期是短暂的,当Pod终止时,其中的数据通常也会被销毁。为了解决这个问题,Kubernetes引入了Persistent Volume(PV)的概念。PV是集群中的一…

springboot/ssm物业管理系统Java小区物业缴费停车管理系统

springboot/ssm物业管理系统Java小区物业缴费停车管理系统 开发语言:Java 框架:springboot(可改ssm) vue JDK版本:JDK1.8(或11) 服务器:tomcat 数据库:mysql 5.7&am…

C语言—指针(3)

嘿嘿嘿嘿,你看我像指针吗? 不会写,等我啥时候会写了再说吧,真的累了,倦了,有没有大佬教教我啊 1.面试题 1)定义整形变量i; 2)p为指向整形变量的指针变量&…

leetcode 1806. 还原排列的最少操作步数

题目链接:leetcode 1806 1.题目 给你一个偶数 n​​​​​​ ,已知存在一个长度为 n 的排列 perm ,其中 perm[i] i​(下标 从 0 开始 计数)。 一步操作中,你将创建一个新数组 arr ,对于每个 …

5.12 BCC工具之undump.py解读

一,工具简介 undump工具用于ump UNIX 套接字数据包。这需要对内核函数进行动态跟踪,并且需要更新以匹配内核的改动。 二,代码示例 #!/usr/bin/python # @lint-avoid-python-3-compatibility-imports #from __future__ import print_function from bcc import BPF from bc…