MASA Framework - 整体设计思路
源起
年初我们在找一款框架,希望它有如下几个特点:
学习成本低
只需要学.Net每年主推的技术栈和业务特性必须支持的中间件,给开发同学减负,只需要专注业务就好
个人见解:一款好用的框架应该是补充,而不是颠覆或过度创新
对扩展开放
可以按照业务需求任意调整依赖实现,而不被捆绑在一个架构思路上
功能强大却不限制架构,从单体到SOA再到微服务都可以适应
因为一个系统中总有复杂的也有简单的,最好能全面覆盖我们的业务场景
行业不限
既能支持传统行业的业务特殊性,又可以支持互联网行业的高并发特性
稳定性
有严格的测试标准,用起来更安心
契机
在我们做技术选型的时候,对Dapr的研究越深入,对我们想要做的事情就越清晰
站在Dapr的设计上我们找到了一个平衡点,Mecha
可以看下这篇文章(Mecha:将Mesh进行到底):https://skyao.io/talk/202004-mecha-mesh-through-to-the-end/
Mecha的特性
- Mecha是通用的,高度可配置的,可重用的组件,提供分布式原语作为现成的能力
- Mecha 可以与单个Micrologic组件一起部署(Sidecar模式),也可以部署为多个共享(注:我称之为Node模式)
- Mecha不对Micrologic运行时做任何假设。它与使用开放协议和格式(例如HTTP/gRPC,JSON,Protobuf,CloudEvents)的多语言微服务甚至单体一起使用
- Mecha以简单的文本格式(例如YAML,JSON)声明式地配置,指示要启用的功能以及如何将其绑定到Micrologic端点
- 与其依靠多个代理来实现不同的目的(例如网络代理,缓存代理,绑定代理),不如使用一个Mecha提供所有这些能力
换个角度看Mecha
Mecha提供的是能力,不论是单体还是分布式
Mecha与服务之间交互是有开放API标准的
Mecha可以通过文本格式(Yaml或Json)声明式地配置
对于.Net开发来说,更习惯用Json
应用需要多种多样的能力,Mecha提供了一整套解决方案却不强绑定你所有都要用到,按需即可
每个能力有不同的实现版本,可以根据自身业务情况替换其中某一部分的能力
为什么是Mecha
Mecha的好处是业务逻辑和越来越多的分布式系统问题之间的松耦合,除了可以解决分布式以外,我们是否也可以延展成业务逻辑和架构之间的松耦合?
当然,说到底就是dll而已

在分布式架构中,它以Sidecar的形式守护在应用身旁。
如果在.Net项目中,它是否可以类似.Net Framework作为基建/适配器/中间件/总线等身份驻留在.Net进程中提供基础能力?
设计思路
一个完整的设计要先从概念开始,为了降低学习成本我们直接复用Dapr的概念定义
概念
构建块
提供接口标准,并为了达到某个基础能力的串接不同组件(也通过接口),松耦合但不脱钩
组件
基于接口标准的实现,比如服务间通讯提供HttpClient和Dapr Service Invocation等不同组件的实现
工具库
提供更抽象的底层能力,供业务和组件完成自身功能,如缓存/配置/数据操作/安全等
Roadmap - v1.0
- 基于.Net主推技术栈,不魔改,降低学习成本
- 提供项目模板,根据业务需求自由组合功能集合
- 支持单体架构,也支持分布式架构
- 支持DDD方法论,也支持CQRS
- 尽量小的依赖集合,但不为了小而小
- 约定优于配置
- 有创新,且要经过生产验证

目前进展
我们首先完成了用于指导架构相关的部分,如DDD、CQRS、Minimal APIs扩展等,并保持单元测试覆盖率在90%以上,目前93%。
以Contrib的目录结构为例:
MASA.Contrib
├── solution items
│ ├── nuget.config
├── src
│ ├── BasicAbility
│ │ ├── MASA.Contrib.BasicAbility.Dcc Configuration API
│ ├── Configuration
│ │ ├── MASA.Contrib.Configuration
│ ├── Data
│ │ ├── MASA.Contrib.Data.UoW.EF Unit of work
│ │ └── MASA.Contrib.Data.Contracts.EF Protocol EF version
│ ├── DDD
│ │ ├── MASA.Contrib.DDD.Domain In-process and cross-process support
│ │ └── MASA.Contrib.DDD.Domain.Repository.EF
│ ├── Dispatcher
│ │ ├── MASA.Contrib.Dispatcher.Events In-process event
│ │ ├── MASA.Contrib.Dispatcher.IntegrationEvents.Dapr
│ │ └── MASA.Contrib.Dispatcher.IntegrationEvents.EventLogs.EF Cross-process event
│ ├── ReadWriteSpliting
│ │ └── CQRS
│ │ │ └── MASA.Contrib.ReadWriteSpliting.CQRS CQRS
│ ├── Service
│ │ └── MASA.Contrib.Service.MinimalAPIs Best practices for [MinimalAPI]
├── test
│ ├── MASA.Contrib.Dispatcher.Events
│ │ ├── MASA.Contrib.Dispatcher.Events.BenchmarkDotnetTest
│ │ ├── MASA.Contrib.Dispatcher.Events.CheckMethodsParameter.Tests
│ │ ├── MASA.Contrib.Dispatcher.Events.CheckMethodsParameterNotNull.Tests
│ │ ├── MASA.Contrib.Dispatcher.Events.CheckMethodsParameterType.Tests
│ │ ├── MASA.Contrib.Dispatcher.Events.CheckMethodsType.Tests
│ │ ├── MASA.Contrib.Dispatcher.Events.OnlyCancelHandler.Tests
│ │ ├── MASA.Contrib.Dispatcher.Events.CheckMethodsType.Tests
│ │ ├── MASA.Contrib.Dispatcher.Events.Tests
│ ├── MASA.Contrib.Data.UoW.EF.Tests
│ ├── MASA.Contrib.Dispatcher.IntegrationEvents.EventLogs.EF.Tests
│ ├── MASA.Contrib.DDD.Domain.Tests
│ ├── MASA.Contrib.DDD.Domain.Repository.EF.Tests
有什么新功能
- Minimal APIs支持类似Controller的API分类聚合
- Event Bus支持Hanlder编排、SAGA、Middleware、事务控制、Event和Hanlder解耦模式。相较于MediatR性能仅有0.x%的差距但功能更加强大,可以面对更复杂的业务场景,并且已规划性能优化路线
- Integration Event Bus是Event Bus的增强版,支持分布式事务(最终一致性),与Dapr集成
- Domain Event Bus是Event Bus和Integration Event Bus的集成版,支持在领域内自动控制进程内与进程外的事件,支持实时发送也支持入栈后统一发送
更多功能等你来体验,也欢迎提意见
什么是MASA
MASA = Mesh Application Service Architecture,即网格应用服务架构
除了MASA Framework,我们马上将开源Blazor组件库(MASA Blazor),包括管理后台模板(MASA Blazor Pro)
后续还有MASA Stack开源产品,基于MASA Framework打造的一站式PaaS平台,具备DevOps、微服务观测治理、数据治理等平台级能力
示例 - MASA.EShop
MASA.EShop是使用MASA.Framework复刻了eShopOnDapr的功能,并提供了多种架构方式的示例。
- 支持Docker Compose
- dapr component配置
- Blazor版EShop网站(正在筹备更换为MASA Blazor Pro的UI)
- 共享Contracts
- 所有服务都使用Minimal APIs和Dapr Pub/Sub进行通信
- MASA.EShop.Services.Basket演示单体架构,使用Dapr State Management
- MASA.EShop.Services.Catalog演示CQRS,使用CQRS、贫血模型
- MASA.EShop.Services.Ordering演示CQRS与Actor,使用CQRS、贫血模型、Dapr Actor
- MASA.EShop.Service.Payment演示CQRS与DDD,使用CQRS、DDD、充血模型

开源地址
MASA.BuildingBlocks:https://github.com/masastack/MASA.BuildingBlocks
MASA.Contrib:https://github.com/masastack/MASA.Contrib
MASA.Utils:https://github.com/masastack/MASA.Utils
MASA.EShop:https://github.com/masalabs/MASA.EShop
MASA Framework - 整体设计思路的更多相关文章
- MASA Framework - EventBus设计
目录 MASA Framework - 整体设计思路 MASA Framework - EventBus设计 概述 利用发布订阅模式来解耦不同架构层级,亦可用于解决隔离业务之间的交互 优点: 松耦合 ...
- MASA Framework - DDD设计(1)
目录 MASA Framework - 整体设计思路 MASA Framework - EventBus设计 MASA Framework - MASA Framework - DDD设计(1) DD ...
- MASA Framework - DDD设计(2)
目录 MASA Framework - 整体设计思路 MASA Framework - EventBus设计 MASA Framework - MASA Framework - DDD设计(1) MA ...
- legend2---开发日志1(legend的数据库整体设计思路是什么)
legend2---开发日志1(legend的数据库整体设计思路是什么) 一.总结 一句话总结:不同种类的物品分不同的表放,不放到一个物品表里,取所有物品时一个个表的取就好了 不同种类的物品分不同的表 ...
- [三]JavaIO之IO体系类整体设计思路 流的概念以及四大基础分类
从本文开始,将正式进入JavaIO的简介 在继续javaIO系列的文章之前 可以过去看一下 本人博客上的设计模式中的 适配器模式和装饰器模式 这会对接下来的阅读大有帮助 本文是从逻辑上介绍整个的J ...
- ibatis源码学习1_整体设计和核心流程
背景介绍ibatis实现之前,先来看一段jdbc代码: Class.forName("com.mysql.jdbc.Driver"); String url = "jdb ...
- MASA Auth - 从用户的角度看整体设计
用户 在系统里,用户是一个核心概念.它代表了一个人的唯一身份标识,除了与角色.团队.组织架构等有关,甚至还会影响到在同一个界面不同的用户操作流程与显示内容都会发生变化,再复杂一点的话,或许在同一个系统 ...
- 万字详解TDengine 2.0整体架构设计思路
导读:涛思数据8月3日将TDengine 的集群功能开源,TDengine具有超强的性能和功能,为什么能做到?它到底有哪些技术创新?今将TDengine的整体设计文档分享出来. 1: 数据模型 物联 ...
- MASA Framework -- EventBus入门与设计
概述 事件总线是一种事件发布/订阅结构,通过发布订阅模式可以解耦不同架构层级,同样它也可以来解决业务之间的耦合,它有以下优点 松耦合 横切关注点 可测试性 事件驱动 发布订阅模式 通过下图我们可以快速 ...
随机推荐
- Frequency函数(Excel函数集团)
此处文章均为本妖原创,供下载.学习.探讨! 文章下载源是Office365国内版1Driver,如有链接问题请联系我. 请勿用于商业!谢谢 下载地址:https://officecommunity-m ...
- DG修复:异常关库导致的数据库启动失败ORA-01110及GAP修复
问题描述:正在应用的备库是一套11.2.0.4的rac环境,但是被直接crsctl stop cluster集群强制关库,重新启动之后导致数据库启动失败,报错 Errors in file /u01/ ...
- AcWing 466. 回文日期
题目: 在日常生活中,通过年.月.日这三个要素可以表示出一个唯一确定的日期. 牛牛习惯用 8 位数字表示一个日期,其中,前 4 位代表年份,接下来 2 位代表月份,最后 2 位代表日期. 显然:一个日 ...
- 使用docker自定义oraclejdk启动jar包
Dockerfile文件 FROM centos:7 #把java与tomcat添加到容器中 ADD jdk-8u161-linux-x64.tar.gz /usr/local/ #安装 vim编辑器 ...
- Linux执行脚本报错:-bash: ./xx.sh: /bin/bash^M: bad interpreter: No such file or directory
1.用vim打开文本 输入 : set ff 这里要先按":"号 显示文件为dos格式 2.强制装换格式为unix 先按冒号":" set ff=unix 然后 ...
- 重学c#系列——datetime 和 datetimeoffset[二十一]
前言 简单介绍一下datetime和 datetimeoffset. 正文 了解一个国家的文化,就要了解一个国家的历史. 要了解datetimeoffset,那么很有必要了解一下datetime. 表 ...
- Qt5获取可用串口
概述 本文将介绍Qt5使用类QSerialPortInfo获取可以用串口号 效果 机器上配置的虚拟串口 程序获取结果 源码开始 .pro文件中添加下面的代码 QT += serialport 然后,执 ...
- 网络编程之UDP(3)丢包总结
读书笔记 from here UDP socket缓冲区满造成的UDP丢包 如果socket缓冲区满了,应用程序没来得及处理在缓冲区中的UDP包,那么后续来的UDP包会被内核丢弃,造成丢包.在sock ...
- 【九度OJ】题目1169:比较奇偶数个数 解题报告
[九度OJ]题目1169:比较奇偶数个数 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1169 题目描述: 第一行输入一个数,为n, ...
- 【LeetCode】16. 3Sum Closest 最接近的三数之和
作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 个人公众号:负雪明烛 本文关键词:3sum, three sum, 三数之和,题解,lee ...