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许可证

编辑推荐精选

咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

AI助手热门AI工具AI创作AI辅助写作讯飞绘文内容运营个性化文章多平台分发
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

TRELLIS

TRELLIS

用于可扩展和多功能 3D 生成的结构化 3D 潜在表示

TRELLIS 是一个专注于 3D 生成的项目,它利用结构化 3D 潜在表示技术,实现了可扩展且多功能的 3D 生成。项目提供了多种 3D 生成的方法和工具,包括文本到 3D、图像到 3D 等,并且支持多种输出格式,如 3D 高斯、辐射场和网格等。通过 TRELLIS,用户可以根据文本描述或图像输入快速生成高质量的 3D 资产,适用于游戏开发、动画制作、虚拟现实等多个领域。

ai-agents-for-beginners

ai-agents-for-beginners

10 节课教你开启构建 AI 代理所需的一切知识

AI Agents for Beginners 是一个专为初学者打造的课程项目,提供 10 节课程,涵盖构建 AI 代理的必备知识,支持多种语言,包含规划设计、工具使用、多代理等丰富内容,助您快速入门 AI 代理领域。

AEE

AEE

AI Excel全自动制表工具

AEE 在线 AI 全自动 Excel 编辑器,提供智能录入、自动公式、数据整理、图表生成等功能,高效处理 Excel 任务,提升办公效率。支持自动高亮数据、批量计算、不规则数据录入,适用于企业、教育、金融等多场景。

UI-TARS-desktop

UI-TARS-desktop

基于 UI-TARS 视觉语言模型的桌面应用,可通过自然语言控制计算机进行多模态操作。

UI-TARS-desktop 是一款功能强大的桌面应用,基于 UI-TARS(视觉语言模型)构建。它具备自然语言控制、截图与视觉识别、精确的鼠标键盘控制等功能,支持跨平台使用(Windows/MacOS),能提供实时反馈和状态显示,且数据完全本地处理,保障隐私安全。该应用集成了多种大语言模型和搜索方式,还可进行文件系统操作。适用于需要智能交互和自动化任务的场景,如信息检索、文件管理等。其提供了详细的文档,包括快速启动、部署、贡献指南和 SDK 使用说明等,方便开发者使用和扩展。

下拉加载更多