
eShopOnContainers 知多少[4]:Catalog microservice
发布日期:2021-05-09 06:35:56
浏览次数:10
分类:博客文章
本文共 1934 字,大约阅读时间需要 6 分钟。
引言
Catalog microservice(目录微服务)维护着所有产品信息,包括库存、价格。所以该微服务的核心业务为:
- 产品信息的维护
- 库存的更新
- 价格的维护
架构模式
如上图所示,本微服务采用简单的数据驱动的CRUD微服务架构,来执行产品信息的创建、读取、更新和删除(CRUD)操作。
这种类型的服务在单个 ASP.NET Core Web API 项目中即可实现所有功能,该项目包括数据模型类、业务逻辑类及其数据访问类。其项目结构如下:核心技术选型:
- ASP.NET Core Web API
- Entity Framework Core
- SQL Server
- Swashbuckle(可选)
- Autofac
- Eventbus
- Polly
实体建模
该微服务的核心领域实体是商品,其类图如下:
对于实体这一块,有两个小知识点需要说明一下:
- 进行数据库字段映射时,主键都使用了
ForSqlServerUseSequenceHiLo
指定使用HI-LO
高低位序列进行主键生成。 - 使用NoTracking提升查询速度在
CatalogController
的构造方法中,明确指定以下代码来进行查询优化,这一点也是我们值得学习的地方。((DbContext)context).ChangeTracker.QueryTrackingBehavior = QueryTrackingBehavior.NoTracking;
- 在进行种子数据的预置时,使用了
Polly
开启了Retry机制。
private Policy CreatePolicy( ILoggerlogger, string prefix,int retries = 3){ return Policy.Handle (). WaitAndRetryAsync( retryCount: retries, sleepDurationProvider: retry => TimeSpan.FromSeconds(5), onRetry: (exception, timeSpan, retry, ctx) => { logger.LogTrace($"[{prefix}] Exception {exception.GetType().Name} with message ${exception.Message} detected on attempt {retry} of {retries}"); } );}public async Task SeedAsync(CatalogContext context,IHostingEnvironment env,IOptions settings,ILogger logger){ var policy = CreatePolicy(logger, nameof(CatalogContextSeed)); await policy.ExecuteAsync(async () => { //... }); }
数据库表结构
你肯定会好奇为什么会多了一张IntegrationEventLog
表,这里先按住不表。 最后
如果eShopOnContainers采用的是单体式应用架构而非微服务架构,那么以上业务逻辑的实现并不复杂,使用简单的CRUD再辅以ACID事务就能很好的完成业务需求。本文的介绍也就可以到此为止了。
然而将其抽取出来成为独立的基础微服务,那么我们要考虑的问题就多了。比如:
- 修改产品价格时,需要同步更新购物车中保存的产品信息的价格。
- 下订单时,需要验证当前商品库存是否充足,进行锁库抢占,以避免库存不足导致的订单无效。
而这一切我们都不能再享受单体应用中直接使用ACID事务的便利了。因为在微服务应用里,产品表和购物篮表被各自的微服务所占有。任何微服务不应该在自己的事务中包含其他微服务的表或存储,即使是直接查询也是不可以的。目录微服务不能直接更新购物篮表,因为购物篮表被购物篮微服务占有。要更新购物篮微服务,产品微服务应该使用基于异步通信,如集成事件(消息和基于事件的通信)来实现最终一致性。
那下一节我们就来详细阐述eShopOnContainers是如何通过事件机制完成最终一致性的。
发表评论
最新留言
第一次来,支持一个
[***.219.124.196]2025年03月30日 03时22分38秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
ASP.NET MVC的Action Filter
2019-03-06
MonoMac 1.0正式发布
2019-03-06
Shawn Wildermuth的《Architecting WP7 》系列文章
2019-03-06
2011 ASP.NET/IIS MVP
2019-03-06
[腾讯社区开放平台].NET SDK基于New BSD协议开源
2019-03-06
使用Topshelf 5步创建Windows 服务
2019-03-06
Powershell中禁止执行脚本解决办法
2019-03-06
Caliburn Micro for Windows Phone 7
2019-03-06
私有代码存放仓库 BitBucket
2019-03-06
Redis Web界面管理工具
2019-03-06
用Sysctl 调整Linux操作系统的性能
2019-03-06
微软以Apache许可协议开源ASP.NET MVC
2019-03-06
HTTP协议状态码详解(HTTP Status Code)
2019-03-06
SQL Server 2012将与Hadoop无缝集成
2019-03-06
CentOS 6上的redis搭建实战记录
2019-03-06
亲密接触IIS 8和Web Deploy 3.0
2019-03-06
強大的jQuery Chart组件-Highcharts
2019-03-06
贝叶斯过滤算法
2019-03-06
CentOS 6下安装nodejs 0.9.0
2019-03-06