.NETCore 千星项目模块化开发框架 SimplCommerce 详解
SimplCommerce 是 github 上过千星的.netcore 商城示例项目,本文详解他的模块化框架现实思路,其业务(如产品、订单)不作介绍。因作者文笔水平很差,它又很值得学习和推荐,就算不要脸献丑一次吧,如对本文有不明白之处望见谅留言,谢谢。
早期单体开发框架,因为简单上手快的特点广受青睐。但是随着项目时间的考验,最终变得难以维护,臃肿、规范、污染等劣势导致人力成本增加。文章后方有 ABP、微服务、模块化、单体应用场景分析。
SimplCommerce 特点
分解
一个超级大的项目,主程可以按功能拆分成N个平行的小模块,每位开发成员都清楚自己负责的模块。
如上图: Modules 目录里的子项目都是分解后的模块
独立
新人是项目开发中最具破坏力的元凶之一,模块间独立、隔离可以有效的限制他们,避免核心模块或整体污染。
每个模块可以有自己的数据库、配置(appsettings.json)、Controller、Views(razor模板)、wwwroot(静态资源)
可扩展性
策划说要增加代理功能,新增一个模块来开发,既不影响原有模块,对开发人员等同是新的小项目,从而更简单。
这个雪球可以一直滚下去,哪怕增加100个新模块,给兵就能打胜仗。
可维护性
得益于分解、独立特性,每个模块代码更少,交接成本、调试成本更低。
举一个极端的例子,需求改不动了怎么办,重构此模块也不过如此吧,不必牵一发而动全身。
可组合性
模块可单独、或者组合部署。
比如独立部署:Modules/SimplCommerce.Module.Orders 由于访问量较大独立到 A 服务器
比如组合部署:Modules/SimplCommerce.Module.Catalog、Modules/SimplCommerce.Module.Cms 由于没有压力独立到 B 服务器
SimplCommerce 模块化框架现实分析
如上图,这是 Catalog 模块的目录结构,看上去和普通和 mvc 没什么区别,仔细看他还少了点什么,对。。。没有 Program.cs、Startup.cs
问:他怎么启动运行呢?
答:模块只负责现实功能,SimplCommerce.WebHost 才是启动项目。
问:SimplCommerce.WebHost 启动怎么加载 Catalog 里的 mvc 代码?
答:请看 SimplCommerce.WebHost/SimplCommerce.WebHost.csproj
<Target Name="CopyModules" AfterTargets="Build">
<Exec WorkingDirectory="." Command="npm run gulp-copy-modules -- --configurationName $(ConfigurationName)" />
</Target>
编译成功后执行 npm run gulp-copy-modules(源码在 SimplCommerce.WebHost/gulpfile.js),采用 node + gulp 将 Modules 所有模块编译结果与所需资源复制到 WebHost 目录之下。
编译成功后的伪动作大致如下:
复制 SimplCommerce.Module.Catalog/bin/Catalog.dll 到 SimplCommerce.WebHost/Modules/Catalog/Catalog.dll
复制 SimplCommerce.Module.Catalog/Views/* 到 SimplCommerce.WebHost/Modules/Catalog/Views/
复制 SimplCommerce.Module.Catalog/appsettings.json 到 SimplCommerce.WebHost/Modules/Catalog/appsettings.json
复制 SimplCommerce.Module.Catalog/wwwroot/* 到 SimplCommerce.WebHost/wwwroot/
dotnet 运行 SimplCommerce.WebHost 时做了以下现实:
1、反射加载 Modules/Catalog/Catalog.dll、Modules/Catalog/Views,由于现实代码过多,本文不贴出(现实源码在此:SimplCommerce.WebHost/Extensions/ServiceCollectionExtensions.cs)
2、合并 appsettings.json 配置文件,采取了类似以下的代码
var confg = new ConfigurationBuilder()
.SetBasePath(env.ContentRootPath)
.AddJsonFile("appsettings.json", true, true)
.AddJsonFile("Modules/Catalog/appsettings.json", true, true);
3、wwwroot 已自然合并。。
问:SimplCommerce.WebHost 需要经常维护吗?
答:不需要,它实现了动态加载模块,项目开发人员只需要负责较简单的 Module。
问:如果模块定义太多,如何全部编译?
答:由于 vs 太方便,右击 Modules 目录就可以全部编译了。
源码地址:https://github.com/simplcommerce/SimplCommerce
特别介绍,由于作者太菜2016年转型 .net core 项目时,它就已经过了千星,星多代表着生态,且用且珍惜。
各大开发框架应用场景分析
ABP
基于 DDD 开发的实践项目,.NETCore 2.0发布以后,国内很多个人用它学习上手,也有公司开始使用它开发项目。
绝对是大团队才伤得起的选择,学习和使用成本较高,作者编程13年玩不转它,您要说我菜,我认。
它的缺点很多我就不说了,因为ABP粉丝太多怕被喷死。。至少他不适合我。
微服务
不多作介绍,这个词是个程序员都听过了解过,有很多实践项目如eShopOnContainers,有人说玩转他就通了一切。
我是这样理解微服务应用场景的:
1、只有当服务器压力很大的情况下,才考虑拆拆分微服务。
2、只有需求变动较小、访问量超大的情况下,才考虑微服务架构,比如电商。
它需要很强的架构师。
它不适合小团队。
它不适合做需求泛滥的项目。
它不适合功能型太复杂的项目。
模块化
本文介绍的即是模块化开发框架,天生适合中大型项目开发,并且为以后拆分成微服务架构奠定了基础。
单体
适合个人或小型项目,优点:快。
总结
每种技术框架存在即是合理的,各有优点和缺点,没有哪个最好哪个最坏,在合适的场景选择合适的框架,它就是把双刃剑,反之将贻误终生。
花了半天时间写这篇文章,希望点赞的兄弟下个月能加工资500,谢谢观看。
.NETCore 千星项目模块化开发框架 SimplCommerce 详解的更多相关文章
- .NET Core Community 第四个千星项目诞生:微服务框架 Surging
本文所有打赏将全数捐赠于 NCC(NCC 的资金目前由 倾竹大人 负责管理),请注明捐赠于 NCC.捐赠情况将由倾竹大人在此处公示. 提及 .NET 微服务,我们脑海中浮现的一系列印象中,总有 Sur ...
- 首次GitHub千星项目提交维护成功 留念
现在有点激动,可能有混乱的地方.请大家见谅. 一直觉得千星项目,对我来说是一个遥不可及的地方.没想到第一次在GitHub上 提交Pull Request 就成功了,并且是一个千星项目. 虽然 只是提出 ...
- Spring4.X + spring MVC + Mybatis3 零配置应用开发框架搭建详解(1) - 基本介绍
Spring4.X + spring MVC + Mybatis3 零配置应用开发框架搭建详解(1) - 基本介绍 spring集成 mybatis Spring4.x零配置框架搭建 两年前一直在做后 ...
- p2p网贷项目开发全过程技术详解,应用框架是ci2.2
p2p网贷项目开发全过程技术详解,应用框架是ci2.2 很标准的mvc开发代码,代码也很简单,方便二次开发 这篇文章会不断更新
- Android项目刮刮奖详解(二)
Android项目刮刮奖详解(一) 前言 上期我们简单地实现了一个画板的功能,用户可以在上面乱写乱画,其实,刮刮奖也是如此,用户刮奖的时候也是乱写乱画的. 刮刮奖原理 一共有两层画布,底层画布存放中奖 ...
- Android项目刮刮奖详解(三)
Android项目刮刮奖详解(二) 前言 上一期我们已经实现了一个简易的刮刮卡功能,这一期我们来将其完善一下 目标 将刮刮奖的宽高改为合适高度 将刮刮奖位置居中 将信息层的图片换成文字(重点) 实现 ...
- Android项目刮刮奖详解(四)
Android项目刮刮奖详解(三) 前言 上一期我们已经是完成了刮刮卡的基本功能,本期就是给我们的项目增加个功能以及美化一番 目标 增加功能 用户刮卡刮到一定程度的时候,清除遮盖层 在遮盖层放张图片, ...
- Android项目刮刮奖详解扩展篇——开源刮刮奖View的制作
Android项目刮刮奖详解(四) 前言 我们已经成功实现了刮刮奖的功能了,本期是扩展篇,我们把这个View直接定义成开源控件,发布到JitPack上,以后有需要也可以直接使用,关于自定义控件的知识, ...
- 项目log4j日志管理详解
项目log4j日志管理详解 log4j日志系统在项目中重要性在这里就不再累述,我们在平时使用时如果没有特定要求,只需在log4j.properties文件中顶入输出级别就行了.如果要自定义输出文件,对 ...
随机推荐
- StringBuffer与StringBuilder
有些时候,需要由较短的字符串构建字符串.比如,按键或来自文件中的单词.采用字符串连接的方式达到此目的效率比较低.每次连接字符串的时候,都会构建一个新的String对象,既耗时,又浪费空间.使用Stri ...
- 第六章之S5PV210正确启动u-boot
1,根据上一章最后一步生成u-boot写入到板子上,生成如下代码 UARU 0x43110220 DDR IS OK! 0x12345678 0xEA000014 U-Boot - ::) CPU: ...
- Shell脚本中获取select值
最近做一个数据清理,根据行号清理,所以需要查出这个行的最大最小值出来进行删除,如果靠手动每次去查,太麻烦所以就用在sh脚本当中执行SELECT语句,并将结果赋值给一个变量. sh脚本如下 #! /bi ...
- py文件转换为exe文件
遇到这个问题时在网上找了一会资料,很多博客的方法很旧了,介绍一种最简单的,pyinstaller. 时间比较早的资料还在介绍如何安装pip(python的包管理器),其实python中已经自带pip了 ...
- C#关于winform时间格式2017.05.27
winform中的控件为DateTimePicker DateTime startdate = startTime.Value;//获取到Winform控件的时间 String start = sta ...
- ASP.NET CORE Linux发布工具(文件对比 只上传差异文件;自动启停WebServer命令;上传完成自动预热WebServer)
最近这几日在搞一个小网站:教你啊 :(感兴趣的朋友可以来捧场,在这个网站上有任何消费我都可以退还) 由于更新频繁,手动更新特别麻烦,于是开发了这个小工具 用了一段时间,还是挺顺手的,同时.NET Co ...
- web页面测试
一.Web的功能测试 1.超链接测试 a.链接与链接的说明文字要匹配 (注:也可以是图片) b.链接的文字要描述正确 c.链接的文字要精简有效 d.链接 ...
- HTTPS加密原理
http(超文本传输协议) 一种属于应用层的协议 缺点: 通信使用明文(不加密),内容可能会被窃听 不验证通信方的身份,因此有可能遭遇伪装 无法证明报文的完整性,所以有可能已遭篡改 优点: 传输速度快 ...
- jQuery学习之旅 Item4 细说DOM操作
jQuery-–DOM操作(文档处理) Dom是Document Object Model的缩写,意思是文档对象模型.DOM是一种与浏览器.平台.语言无关的接口,使用该接口可以轻松访问页面中所有的标准 ...
- 你不知道的JavaScript--Item21 漂移的this
而在 JavaScript 中,this 是动态绑定,或称为运行期绑定的,这就导致 JavaScript 中的 this 关键字有能力具备多重含义,带来灵活性的同时,也为初学者带来不少困惑.本文仅就这 ...