[目录] ASP.Net Core 搭建微服务网站

本项目采用ASP.Net Core微服务技术,搭建博客和Saas平台。

  全文将围绕(1)设计模式  (2)敏捷开发    html

  目的: 结构足够合理,代码足够优美,扩展性、可读性、易维护性作到最优。linux

如下目录仅为总体思路,后期逐渐完善补充。

1.配置linux环境实现持续集成

2.快速搭建 ASP.net core Web 应用

3.单元测试

4.数据持久化(基于YesSql,打算使用EFCore从新作)

5.用户管理及登陆页面

6.分布式通讯----MessagePack序列化

7.分布式通讯----Netty实现NIO通讯

8.分布式通讯----主机Host

9.分布式服务----Zookeeper注册中心

分布式服务----负载均衡

分布式服务----熔断器

分布式治理----网关

分布式队列----RabbitMq消息组件

分布式缓存----Redis

角色管理

模块管理

菜单(导航)管理

主题配置

日志管理

博客内容管理

用户评论管理

全文检索

接入第三方认证及API治理

调用第三方API服务

工做流管理

定时做业、事件触发

租户(组织单位)管理(Saas)

ERP(简化数据录入、联动、计算)

文件管理

邮件发送与接收

数字证书https管理

业务数据展现处理(报表)

大数据计算

其它技术

 

总体架构设计

首先,灵感来源是微软的一个开源项目OrchardCore:https://github.com/OrchardCMS/OrchardCore, 最开始关注它的时候是.net Framework, 后来转到了 .net coregit

这里是他的官方文档:https://orchardcore.readthedocs.io/en/dev/  后期有精力的话,我会将它源码分析作一个系列的博客。github

可以实现Saas和Blog比较完善业务功能,并且模块的扩展性很好,可是不是微服务架构,没有服务注册、路由、发现等,很难作到分布式。我画了一张该项目的基础模块包依赖图,用来分析项目依赖关系:设计模式

 

还有一个微服务的开源项目,surging:https://github.com/dotnetcore/surging, 封装了很全的微服务中的服务注册、发现、网关,使用Netty重写了http、WS、Mqtt通讯协议,支持ProtoBuffer、MessagePack序列化方式,Kafka、RabbitMq消息中间件等。缓存

如下是我绘制的包依赖图:架构

 

我着手搭建的项目将参考上述开源项目,总体架构图我后期会作补充和拆解分析。负载均衡

相关文章
相关标签/搜索