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来为主页需要显示的几个部分提供支撑。

 

  系统架构

  整个系统架构如下图所示:

 

  图中,需要注意以下几点:

  1. 微服务之间最脆弱的部分就是服务之间的Http调用,所以需要用Polly库保证安全;
  2. 虽然查询数据库的框架其实效率差不多,但是我还是喜欢原生的SQL,在ADO和Dapper中,还是决定用Dapper,因为想学一下。。。

  今天就先这样吧,下一篇会先把数据库的表间关系设计好,第一次写多多包涵。

posted @ 2019-04-25 19:39  river-and-boat  阅读(674)  评论(0编辑  收藏  举报