dev-store

dev-store

基于ASP.NET 6构建的开源微服务电商应用

DevStore是一个基于ASP.NET 6的开源微服务电商应用,集成了ASP.NET Core、Entity Framework Core和RabbitMQ等主流技术。项目采用六边形架构、领域驱动设计和CQRS等现代架构理念,包含7个API和1个Web应用。作为一个参考实现,DevStore展示了如何使用.NET构建复杂的分布式系统,为开发者提供了学习现代软件架构的实践平台。

DevStore微服务电子商务ASP.NET CoreDockerGithub开源项目
<p align="center"> <img alt="标志" src="https://user-images.githubusercontent.com/5068797/161198565-ac18c5ac-c0d9-4669-9568-b2009e944d77.png#gh-light-mode-only" /> <img alt="标志" src="https://user-images.githubusercontent.com/5068797/161364257-0c1d81f6-62ac-4192-93f8-836b4ce0fd06.png#gh-dark-mode-only" /> </p>

DevStore - 基于ASP.NET 6构建的微服务电子商务参考应用

desenvolvedor.io提供支持的真实世界参考应用 <img alt="巴西" src="https://yellow-cdn.veclightyear.com/2b54e442/c68ed4af-fddd-4c87-9b0b-a83d13105edc.png" width="20" height="14" />,实现了最常见和最常用的技术,旨在与技术社区分享使用.NET开发完整复杂应用程序的最佳方式


本项目受EShopOnContainers启发,但真正的动机是以"我们的方式"构建它。
EShopOnContainers是一个很棒的项目,但代码中存在一些"坏味道"。与DevStore相比,我们发现开始学习/使用EShopOnContainers比较困难。我们喜欢将DevStore视为一个简化(但并不简单)的版本,并在代码和小细节方面更加用心。我们还只专注于使用ASP.NET的Web架构。

给个星星! :star:

如果你喜欢这个项目或者DevStore对你有帮助,请给我们一个星星 ;)

<p align="center"> <img alt="DevStore" src="https://yellow-cdn.veclightyear.com/2b54e442/67be181a-6cb7-4b49-a621-4a74ba5d37de.png" /> </p>

想学习构建这样的应用所需的一切吗? :mortar_board:

查看desenvolvedor.io的在线课程(仅提供葡萄牙语)

实现的技术/组件

  • .NET 6

    • ASP.NET MVC Core
    • ASP.NET WebApi
    • ASP.NET Minimal API
    • ASP.NET Identity Core
    • 刷新令牌
    • 带旋转公钥/私钥的JWT
    • GRPC
    • 后台服务
    • Entity Framework Core 6
  • 组件/服务

    • RabbitMQ
    • EasyNetQ
    • Refit
    • Polly
    • Bogus
    • Dapper
    • FluentValidator
    • MediatR
    • 支持JWT的Swagger UI
    • NetDevPack
    • NetDevPack.Identity
    • NetDevPack.Security.JWT
  • 托管

    • IIS
    • NGINX
    • Docker(带compose)

架构:

完整的架构实现了最重要和常用的关注点,如:

  • 六边形架构
  • 整洁代码
  • 整洁架构
  • DDD - 领域驱动设计(层和领域模型模式)
  • 领域事件
  • 领域通知
  • 领域验证
  • CQRS(即时一致性)
  • 重试模式
  • 断路器
  • 工作单元
  • 仓储
  • 规约模式
  • API网关 / BFF

架构概览

整个应用程序基于一个包含7个API和一个Web应用程序(MVC)的唯一解决方案

<p align="center"> <img alt="先读" src="https://yellow-cdn.veclightyear.com/2b54e442/13502617-323e-4c19-92a0-c51354e5840a.png" /> </p>

这是一个参考应用程序,每个微服务都有自己的数据库,代表一个有界上下文(DDD概念)。 有一个BFF / API网关来管理购物篮/订单/支付请求和响应的数据结构。

<p align="center"> <img alt="先读" src="https://yellow-cdn.veclightyear.com/2b54e442/683cf7a7-7d8c-49e2-bd5b-c70a774d0f1a.png" /> </p>

入门

你可以在任何操作系统上运行DevStore项目。确保你的环境中已安装Docker。获取Docker安装

克隆DevStore仓库并导航到**/Docker**文件夹,然后:

如果你只想在Docker环境中运行DevStore应用程序:

docker-compose up

如果你想构建本地镜像并在Docker环境中运行DevStore应用程序:

这个compose将为每个API服务提供一个数据库容器。

docker-compose -f docker-compose-local.yml up --build

如果你更喜欢节省机器资源,请使用轻量级本地compose:

这个compose将为所有API服务提供一个数据库容器。

docker-compose -f docker-compose-local-light.yml up --build

如果你想在VS/VS Code中本地运行:

你需要:

  • Docker
  • SQL实例(或容器)
  • RabbitMQ

这样你就可以编辑Docker compose来只运行数据库和队列依赖,节省时间。

如果你想要Visual Studio的F5和调试体验:

image


如果你想要Visual Studio Code体验:

  • 在根目录(解决方案文件)打开VS Code
  • 在VS Code调试部分创建一个新的launch.json,并使用以下配置来设置"启动所有项目"选项
{ "version": "0.2.0", "configurations": [ { "name": "DevStore MVC WebApp", "type": "coreclr", "request": "launch", "preLaunchTask": "build", "program": "${workspaceFolder}/src/web/DevStore.WebApp.MVC/bin/Debug/net6.0/DevStore.WebApp.MVC.dll", "args": [], "cwd": "${workspaceFolder}/src/web/DevStore.WebApp.MVC", "console": "internalConsole", "stopAtEntry": false }, { "name": "DevStore Billing API", "type": "coreclr", "request": "launch", "preLaunchTask": "build", "program": "${workspaceFolder}/src/services/DevStore.Billing.API/bin/Debug/net6.0/DevStore.Billing.API.dll", "args": [], "cwd": "${workspaceFolder}/src/services/DevStore.Billing.API", "console": "internalConsole", "stopAtEntry": false }, { "name": "DevStore Catalog API", "type": "coreclr", "request": "launch", "preLaunchTask": "build", "program": "${workspaceFolder}/src/services/DevStore.Catalog.API/bin/Debug/net6.0/DevStore.Catalog.API.dll", "args": [], "cwd": "${workspaceFolder}/src/services/DevStore.Catalog.API", "console": "internalConsole", "stopAtEntry": false }, { "name": "DevStore Customers API", "type": "coreclr", "request": "launch", "preLaunchTask": "build", "program": "${workspaceFolder}/src/services/DevStore.Customers.API/bin/Debug/net6.0/DevStore.Customers.API.dll", "args": [], "cwd": "${workspaceFolder}/src/services/DevStore.Customers.API", "console": "internalConsole", "stopAtEntry": false }, { "name": "DevStore Identity API", "type": "coreclr", "request": "launch", "preLaunchTask": "build", "program": "${workspaceFolder}/src/services/DevStore.Identity.API/bin/Debug/net6.0/DevStore.Identity.API.dll", "args": [], "cwd": "${workspaceFolder}/src/services/DevStore.Identity.API", "console": "internalConsole", "stopAtEntry": false }, { "name": "DevStore Orders API", "type": "coreclr", "request": "launch", "preLaunchTask": "build", "program": "${workspaceFolder}/src/services/DevStore.Orders.API/bin/Debug/net6.0/DevStore.Orders.API.dll", "args": [], "cwd": "${workspaceFolder}/src/services/DevStore.Orders.API", "console": "internalConsole", "stopAtEntry": false }, { "name": "DevStore ShoppingCart API", "type": "coreclr", "request": "launch", "preLaunchTask": "build", "program": "${workspaceFolder}/src/services/DevStore.ShoppingCart.API/bin/Debug/net6.0/DevStore.ShoppingCart.API.dll", "args": [], "cwd": "${workspaceFolder}/src/services/DevStore.ShoppingCart.API", "console": "internalConsole", "stopAtEntry": false }, { "name": "DevStore BFF Checkout", "type": "coreclr", "request": "launch", "preLaunchTask": "build", "program": "${workspaceFolder}/src/api-gateways/DevStore.Bff.Checkout/bin/Debug/net6.0/DevStore.Bff.Checkout.dll", "args": [], "cwd": "${workspaceFolder}/src/api-gateways/DevStore.Bff.Checkout", "console": "internalConsole", "stopAtEntry": false } ], "compounds": [ { "name": "启动所有项目", "configurations": [ "DevStore MVC WebApp", "DevStore Billing API", "DevStore Catalog API", "DevStore Customers API", "DevStore Identity API", "DevStore Orders API", "DevStore ShoppingCart API", "DevStore BFF Checkout" ], "stopAll": true } ] }

免责声明

  • 这不是新应用程序的架构模板或引导模型
  • 所有实现都是为了真实世界而制作的,但目标是分享知识
  • 你可能不需要许多包含的实现,尽量避免过度工程

拉取请求

提出一个问题,让我们讨论!不要提交未讨论或未批准功能的PR。

如果你想帮助我们,选择一个已批准的问题并实现它。

我们在线上

查看在<a href="https://devstore.academy" target="_blank">DevStore官方实例</a>上运行的项目

关于

DevStore由desenvolvedor.io<img alt="巴西" src="https://yellow-cdn.veclightyear.com/2b54e442/c68ed4af-fddd-4c87-9b0b-a83d13105edc.png" width="20" height="14" />团队自豪地开发,采用MIT许可证

编辑推荐精选

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成AI工具AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机AI图像热门
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

下拉加载更多