ASP.NET Core微服务+Tabler前端框架搭建个人博客2--系统架构
功能分析
在整个微服务架构的搭建过程中,我们需要做的第一步就是对服务进行拆分,将一个完整的系统模块化,通过对各个模块互联,共同完成一个系统的工作。既然要做到模块化,那么必须明白你的系统的需求到底是什么,即你要做的这个系统需要实现哪些功能,明确了功能以后,再对功能进行划分,将具有相似作用的功能划分为一个模块,最后再决定需要用什么样的方式去实现你的模块,最后才是正式开始敲代码。
在我们的个人博客中,我将网站划分为了以下几个部分:
- 主页
主页里面自然需要做一些概况展示,例如:文章总数、访问总数、评论总数、最近文章、最近留言、最热文章、作者推荐等,可以说主页里面跨越了多个模块的访问,那么简单的实现方式就是通过多个Ajax去访问不同的模块来进行动态加载数据。
- 技术随笔
技术随笔中自然是要有文章列表,通过加载文章列表,浏览者可以选择自己感兴趣的文章然后进行查看详情,即文章详情页面。在技术随笔页面,也应该包含最热文章和推荐文章,这样可以方便浏览者进行选择。
- 文章详情
文章详情重点展示的是文章的内容以及文章评论。
- 我的书屋
该模块可以说与技术随笔模块实现方式完全一致,也拥有书籍列表、最热书籍、推荐书籍、书籍详情以及评论,所以可以将它们归纳为一个模块,只需要在Type列进行标记,即可分开。
- 留言板
这里对每个浏览网站的用户提供了留言功能,针对每一条留言,可以有多条回复,对于这种存储结构,用Mo'ngodb存储最为适合。
- 网站管理
这部分包含了留言管理、文章发布等功能,这部分模块自然就需要有权限控制,只有网站管理员才能进行文章发布、留言管理,而一般的用户只有留言网站的权限。
- 身份认证
用于识别用户的身份以及相应权限,为了满足网站扩展性以及迎合目前趋势,身份认证授权我们当然是采用Identity Server4来实现。
模块划分
有了上面的功能的分析,我们接下来可以进行服务划分了。
- Ocelot网关服务
网关服务用于向外提供一个统一的访问地址,而在内部进行请求的转发,你需要在json文件中设置它的上游服务器和下游服务器,这样,所有对上游地址的请求,都会被转发到下游服务器,具体情况等到搭建Ocelot网关服务器的时候再进行详细解释,现在只需要明白,Ocelot的作用就是对外提供一个统一的地址,可以是你的域名,然后它会将请求按配置转发到多个节点上。
- IdentityServer4登陆服务
该服务主要用于提供身份认证和授权,即OAuth2+OpenID Connect,在用户访问一些接口时,如留言等,会要求身份认证,这是就需要进行登陆处理,当验证完毕后,会获得access-token和id-token,然后可以用access-token对接口访问,id-token代表了用户身份。
- 文章/书籍服务
之前说过,文章和书籍服务实现方式完全一致,包括文章/书评发布、评论等,所以将它们归为一个模块。注意,这部分的文章/书评的发布和删除,必须是管理员权限才能管理。
- 留言服务
留言服务归为一个单独的模块,选择Mongodb存储留言列表,留言服务与文章书籍服务交互甚多,引入HttpClient后,一定要用Polly库保证服务的稳定性。留言删除必须是管理员权限才能管理。
- 日志服务
网站日志,比如网站有什么异常啊,或者记录哪个接口延时较大等,以便后续改进,需要注意这部分权限必须为系统管理员才能访问。
- RabbitMQ服务
微服务之间的消息难免需要进行通信,例如,当其他服务发生了异常,需要用日志服务来进行异常记录,但是两个服务不在一个节点上,这种情况就需要使用我们的RabbitMQ来传递异常消息。其他服务利用通过EventBus投递消息,日志服务只需要接收消息进行存储即可。
最后,大家都知道Redis非常适合用于做网站浏览量统计、热度统计等,所以可以使用Redis来为主页需要显示的几个部分提供支撑。
系统架构
整个系统架构如下图所示:
图中,需要注意以下几点:
- 微服务之间最脆弱的部分就是服务之间的Http调用,所以需要用Polly库保证安全;
- 虽然查询数据库的框架其实效率差不多,但是我还是喜欢原生的SQL,在ADO和Dapper中,还是决定用Dapper,因为想学一下。。。
今天就先这样吧,下一篇会先把数据库的表间关系设计好,第一次写多多包涵。
ASP.NET Core微服务+Tabler前端框架搭建个人博客2--系统架构的更多相关文章
- ASP.NET Core微服务+Tabler前端框架搭建个人博客1--开始前想说的话
写在前面 本人为在读研究生,特别喜欢.NET,觉得.NET的编程方式.语法都特别友好,学习.NET Core已经差不多有一年半了,从一开始不知道如何入门到现在终于可以编写一些小的应用程序,想一想还是非 ...
- (6)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- AOP框架
AOP 框架基础 要求懂的知识:AOP.Filter.反射(Attribute). 如果直接使用 Polly,那么就会造成业务代码中混杂大量的业务无关代码.我们使用 AOP (如果不了解 AOP,请自 ...
- ASP.NET Core 微服务初探[1]:服务发现之Consul
ASP.NET Core 微服务初探[1]:服务发现之Consul 在传统单体架构中,由于应用动态性不强,不会频繁的更新和发布,也不会进行自动伸缩,我们通常将所有的服务地址都直接写在项目的配置文件 ...
- 【新书推荐】《ASP.NET Core微服务实战:在云环境中开发、测试和部署跨平台服务》 带你走近微服务开发
<ASP.NET Core 微服务实战>译者序:https://blog.jijiechen.com/post/aspnetcore-microservices-preface-by-tr ...
- webapi框架搭建系列博客
webapi框架搭建系列博客 webapi框架搭建-创建项目(一) webapi框架搭建-创建项目(二)-以iis为部署环境的配置 webapi框架搭建-创建项目(三)-webapi owin web ...
- (7)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- 利用Polly+AOP+依赖注入封装的降级框架
创建简单的熔断降级框架 要达到的目标是: 参与降级的方法参数要一样,当HelloAsync执行出错的时候执行HelloFallBackAsync方法. public class Person { [H ...
- (8)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- Ocelot网关(Api GateWay)
说到现在现有微服务的几点不足: 1) 对于在微服务体系中.和 Consul 通讯的微服务来讲,使用服务名即可访问.但是对于手 机.web 端等外部访问者仍然需要和 N 多服务器交互,需要记忆他们的服务 ...
- (5)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- 熔断降级(Polly)
一. 什么是熔断降级 熔断就是“保险丝”.当出现某些状况时,切断服务,从而防止应用程序不断地尝试执行可能会失败的操作给系统造成“雪崩”,或者大量的超时等待导致系统卡死. 降级的目的是当某个服务提供者发 ...
- (1)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- 什么是微服务架构,.netCore微服务选型
开发工具:VS2017 .Net Core 2.1 什么是微服务?单体结构: 缺点: 1)只能采用同一种技术,很难用不同的语言或者语言不同版本开发不同模块: 2)系统耦合性强,一旦其中一个模块有问题, ...
随机推荐
- 移动端使用fastclick时,模拟原生浏览器对象
移动浏览器原生click事件有300ms的延时,这是浏览器为了区分到底是双击还是单击事件.(实际上有些移动浏览器不支持双击事件.PC版chrome在手机模式下,当禁止用户双击缩放页面时(即有viewp ...
- Difference between Load / Stress / Performance Testing
Load and stress testing are subsets of performance testing. Performance testing means how best somet ...
- Alpha冲刺四
第四天 日期:2018/6/19 1.1 今日完成任务情况以及遇到的问题. 成员 汝春瑞.曹 阳 赵红波.梁玉龙 傅 康.丁炜轩 今日完成任务 设计餐厅每个店家的餐品界面 完成公告和失物招领 ...
- uni-app 顶部导航点击更换图标
更换顶部导航的iconfont.ttf图标,先在配置文件配置好按钮: pages.json文件 "buttons": [ { "text": "\ue ...
- (PMP)解题技巧和典型题目分析(0903-2班)
1.计算题 ,5 2.概念题,少 3.情景题,很多 C B C D ------------------------------------------------------------------ ...
- Day12 (黑客成长日记) 函数
一.递归函数: 在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数. #计算阶乘: def fact(n): if n == 1: return 1 return n ...
- spring InitializingBean和DisposableBean init-method 和destroy-method @PostConstruct @PreDestroy
对于初始化函数: @PostConstruct 注解的方法 InitializingBean接口定义的回调afterPropertiesSet() Bean配置中自定义的初始化函数 对于析构则与上相同 ...
- Python序列结构--集合
集合:元素之间不允许重复 集合属于Python无序可变序列,元素之间不允许重复 集合对象的创建与删除 直接将值赋值给变量即可创建一个集合 >>> a = {3,5}>>& ...
- K-DTree学习
应用于K维数据的快速查找,比如横坐标,纵坐标,价格……,本模板以16青岛区域赛K题为例 —— 三维K - D Tree 模板 我们应该都见过平衡树吧,那就是1-D树,变成k维之后,我们连续分割1 - ...
- Js实现继承的方法
原型的作用:1.将公共部分放入原型中,这样构造出的多个实例对象的公共部分只会占用一个公共空间,实现数据共享和节省内存空间 2.通过原型实现继承:构造函数模拟 "类"这个面向对象的概 ...