首页 后端开发 C#.Net教程 OSS.Core基础思路

OSS.Core基础思路

May 28, 2017 am 11:43 AM

  如今框架两字已经烂大街了,xx公司架构设计随处可见,不过大多看个热闹,这些框架如何来的,细节又是如何思考的,相互之间的隔离依据又是什么...相信很多朋友应该依然存在自己的疑惑,特别是越来越火热的微服务以及衍生的微服务网关产品,正好最近打算写一个小开源框架OSS.Core,过程中有一点思考,通过这篇文章记录一下,也希望能尽量帮助大家去理解一下,大概围绕以下几个问题:

1. 微服务产生的由来

2. 微服务的设计思路

3. OSS.Core框架的设计和实现

  在展开讲述之前,我希望大家首先要明白传统架构和微服务架构之间不是相互独立/对立关系,微服务是在传统框架下为了应对并发维护等问题衍生出的逻辑概念,更多的是在项目不同阶段的思考和解决问题方式的转变。其次,把逻辑架构和物理架构(文件) 区分开来,多数时候逻辑架构和物理架构对应的,不过有时一个物理架构中是可以包含多个逻辑架构的。

一. 微服务产生的由来

      微服务主要是将一些大型的,复杂的应用拆解为多个服务组合,每个服务自治,以达到更加灵活,维护方便的效果。 

  为了更好的理解,我们先来看下常见三种解决并发的方式:

  1. 添加数据库主从分离,甚至多主写入或者分区等机制,在应用程序中对应修改连接串或添加访问中间件,来提高数据库的处理能力。

  2. 由于数据库资源相对紧张并且比较耗时,为了提高访问速度,这个时候一般也会通过分布式缓存等来减少对底层的访问。

  3. 负载均衡分流处理,在大量请求抵达应用程序之前,将其分散到不同的机器上,来解决单机带宽和性能瓶颈问题。

  当然解决并发还有很多其他的方式,如前端静态文件压缩,CDN加速,IP速率控制等,这里先略过。

  以上这三种方法很多朋友应该都见过,之所以这里列一下,再结合这张图可以更加容易的对比出传统整个服务到微服务之间的变化:

  在传统的整体服务框架中,模块之间存在着很大的耦合,项目内部存在互相调用,以及各种复杂聚合操作,所以在多数情况下只能整体部署,在左侧图中我们可以看到负载均衡时我们需要整体部署在多台机器上,相对数据库也是如此,而一个项目中每个模块的需求是不一样的。

  例如:产品和下单模块的访问频率和流程的复杂度上有着很大的不同,下单频率相对较小,复杂度高,我们更希望运行在预算能力高的相对少机器上,也方便更快的排查问题和维护。右图中可以看到把服务细化之后,我们可以用更小的部署单元来根据情况进行组合。

  同时,在互联网产品快速迭代的今天,一个产品需要具有快速为不同终端上线不同应用功能的能力,同时业务的调整能够快速的上线,传统的整体服务模式已经力不从心。微服务因为已经化整为零,反而因为各模块的独立能很快相互组合,并且每个模块可以根据不同的需求点采用不同特性的编程语言

  

 

二. 微服务的设计思路

  因为每个产品都有自己的标准和重点,所以设计服务单元时也各有不同,但是有最基本一点: 服务自治

  当你设计一个微服务模块时,需要保证当前服务的独立,特别是数据模块的独立,其他服务无权直接操作当前服务下的数据库模块,对外交互只能通过服务接口来完成。因为模块的独立,所以你可以选择适合的编程语言,以及对应的部署规模。达到局部的灵活优化。微服务相互独立带来以上便利的同时,它也带来了一些我们需要面对的问题:

  首先:如何如何界定当前服务的边界,如何确定当前服务治理范围。

  既然是要最小化服务单元,那就要确定服务的职责边界问题,这个问题建议结合:服务生命周期流程领域,以及预估规模 这几点综合考虑,例如用户服务,在访问量小人员少时可以把用户基础信息,余额账户放在一个服务模块下,以减少工作量减少精力分散。规模大时再分基础服务和资产服务。

  其次:跨服务数据查询问题

  例如在客户端中搜索商品,还可以搜索用户或者统计数据查询等如何处理。对于这种我给两个处理方式:

  1. API Gateway

  这种情况适合在服务单元过多,客户端需要查询使用不同的服务单元中的数据,这个时候我们可以针对性的搭建一个API服务网关(请注意和APP Gateway区分开),通过这个网关聚合多个服务,客户端只需要和当前网关交互,网关聚合转发给不同的微服务。如下图:

  2. 数据冗余或者后台数据同步

  比如在订单信息中我需要用户的名称等少量用户字段,这个时候完全可以把这几个字段冗余到订单微服务数据模块下。又比如在统计模块下,其数据制造者和查询者完全属于不同的对象,无很高实时性,那我建议创建一个统计服务以及对应的统计数据库,其他服务通过事件消息交互,更新对应的统计数据,查询时通过统计服务自己的数据即可完成。

  再次:如何解决服务间的通信问题

  因为我们已经将服务之间相互独立,断绝直接操作不同服务数据库的可能。那么数据的一致性如何处理,在传统的服务模型中因为都糅合在一块,我们可以通过事务或者存储过程来保证数据的一致性。常见的有以下两个方式:

  1. 异步事件消息驱动

  这类解决方案适合对数据实时性要求相对不高的场景,比如上边的统计服务更新,在下单等服务的事件触发后给消息队列推送响应的消息通知,订阅此队列的服务接收更新数据。如图:

  2. 直接接口请求(HTTP,RPC)

  一般情况下不建议,以防止产生级联依赖。这类主要针对数据实时性要求较高的请求,比如在秒杀下单过程中需要立即知道库存服务扣除是否成功等。(注:.net 下对task的支持已经特别好了,http请求建议使用异步,同时前端返回Task<ActionResult>,减少因IO操作造成的工作线程消耗)

  最后:客户端如何访问

  当我们封装完服务之后,这个服务如何和最后的客户端如何访问,这个需要根据实际的安全规则和要求各自决定了,一般情况下,如果服务相对较少,功能不算复杂的情况下可以直接暴露服务接口给客户端进行访问,如图:

  或者通过上边说的 API Gateway 的形式提供给客户端,当然也有很多已经成熟的微服务网关比如Azure云上的Service Fabric或者API Management,都是可以的。

 

三. OSS.Core框架的思路和实现

  OSS.Core这个项目是我最近在写的一个小开源产品,了解的朋友应该知道我在前面写了一些组件像: OSS.Social,OSS.PayCenter,OSS.Common,OSS.Http 这个项目希望能把这几个组件给串联起来,上边已经介绍了微服务的大概思考方式,我将会在这个产品的逻辑架构中尽可能的体现这一点,先把项目的物理架构图展示一下:

  这个项目中AdminSite,WebSite 放置在FrontEnds文件夹下,两个问站点分别是用户前端,和后台管理前端

  WebApi,Service,DomainMos(图中的Models和Interface)类库在 Layers 文件夹下,构成API基础

  Infrastructure(业务相关通用实体枚举辅助类) 和 Common(业务无关相关实体辅助类) 作为基础设施类库,可以在各级类库中调用

   Repositories(暂时是项目中的OSS.Core.RepDapper的Mysql实现,以后可能增加其他数据库支持),主要是Rep.. Interface的具体实现。

  Plugs是实现了Common插件下的日志,缓存,和配置接口具体实现,可以通过Common在各级直接调用。

      回到微服务的话题上,在这个产品中我不会为每个服务创建一套Layers下的类库实现,我将在这个项目通过文件夹隔离的形式来分开各个服务,你可以把WebApi当做一个API Gateway,内部的调用顺序我希望是这样的:

  现在代码结构图:

 

以上是OSS.Core基础思路 的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1673
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
c#.net的持续相关性:查看当前用法 c#.net的持续相关性:查看当前用法 Apr 16, 2025 am 12:07 AM

C#.NET依然重要,因为它提供了强大的工具和库,支持多种应用开发。1)C#结合.NET框架,使开发高效便捷。2)C#的类型安全和垃圾回收机制增强了其优势。3).NET提供跨平台运行环境和丰富的API,提升了开发灵活性。

从网络到桌面:C#.NET的多功能性 从网络到桌面:C#.NET的多功能性 Apr 15, 2025 am 12:07 AM

C#.NETisversatileforbothwebanddesktopdevelopment.1)Forweb,useASP.NETfordynamicapplications.2)Fordesktop,employWindowsFormsorWPFforrichinterfaces.3)UseXamarinforcross-platformdevelopment,enablingcodesharingacrossWindows,macOS,Linux,andmobiledevices.

C#作为多功能.NET语言:应用程序和示例 C#作为多功能.NET语言:应用程序和示例 Apr 26, 2025 am 12:26 AM

C#在企业级应用、游戏开发、移动应用和Web开发中均有广泛应用。1)在企业级应用中,C#常用于ASP.NETCore开发WebAPI。2)在游戏开发中,C#与Unity引擎结合,实现角色控制等功能。3)C#支持多态性和异步编程,提高代码灵活性和应用性能。

将C#.NET应用程序部署到Azure/AWS:逐步指南 将C#.NET应用程序部署到Azure/AWS:逐步指南 Apr 23, 2025 am 12:06 AM

如何将C#.NET应用部署到Azure或AWS?答案是使用AzureAppService和AWSElasticBeanstalk。1.在Azure上,使用AzureAppService和AzurePipelines自动化部署。2.在AWS上,使用AmazonElasticBeanstalk和AWSLambda实现部署和无服务器计算。

C#和.NET运行时:它们如何一起工作 C#和.NET运行时:它们如何一起工作 Apr 19, 2025 am 12:04 AM

C#和.NET运行时紧密合作,赋予开发者高效、强大且跨平台的开发能力。1)C#是一种类型安全且面向对象的编程语言,旨在与.NET框架无缝集成。2).NET运行时管理C#代码的执行,提供垃圾回收、类型安全等服务,确保高效和跨平台运行。

C#.NET开发:入门的初学者指南 C#.NET开发:入门的初学者指南 Apr 18, 2025 am 12:17 AM

要开始C#.NET开发,你需要:1.了解C#的基础知识和.NET框架的核心概念;2.掌握变量、数据类型、控制结构、函数和类的基本概念;3.学习C#的高级特性,如LINQ和异步编程;4.熟悉常见错误的调试技巧和性能优化方法。通过这些步骤,你可以逐步深入C#.NET的世界,并编写高效的应用程序。

C#.NET:使用.NET生态系统构建应用程序 C#.NET:使用.NET生态系统构建应用程序 Apr 27, 2025 am 12:12 AM

如何利用.NET构建应用?使用.NET构建应用可以通过以下步骤实现:1)了解.NET基础知识,包括C#语言和跨平台开发支持;2)学习核心概念,如.NET生态系统的组件和工作原理;3)掌握基本和高级用法,从简单控制台应用到复杂的WebAPI和数据库操作;4)熟悉常见错误与调试技巧,如配置和数据库连接问题;5)应用性能优化与最佳实践,如异步编程和缓存。

.NET框架与C#:解码术语 .NET框架与C#:解码术语 Apr 21, 2025 am 12:05 AM

.NETFramework是一个软件框架,C#是一种编程语言。1..NETFramework提供库和服务,支持桌面、Web和移动应用开发。2.C#设计用于.NETFramework,支持现代编程功能。3..NETFramework通过CLR管理代码执行,C#代码编译成IL后由CLR运行。4.使用.NETFramework可快速开发应用,C#提供如LINQ的高级功能。5.常见错误包括类型转换和异步编程死锁,调试需用VisualStudio工具。

See all articles