域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。
  • 方案1️⃣AXUM.RS 域名 = 3000
  • 方案2️⃣方案1️⃣ + 本站所有专题原始 Markdown 文档 = 5000
  • 方案3️⃣方案2️⃣ + 本站原始数据库 = 5500
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名(方案1️⃣),或者该域名到期,本站将启用新的免费域名继续提供服务。
  2. 如果有人购买了 AXUM.RS 域名,且同时购买了内容和/或数据库(方案2️⃣/方案3️⃣),本站将关闭。届时我们或许会以另一种方式与你再相遇。

项目结构

本专题相对复杂,规划好结构非常必要。本专题至少包含四大部分:阶段一的单节点商城、阶段二的分布式商城、商城的UI和各种所需要的前置知识。

项目结构

如上文所述,整体看,本专题包含四大部分:

  • 阶段一的单节点商城,我们命名为和整个专题同名的 plaza
  • 阶段二的分布式商城,我们命名为 plaza-distributed
  • 商城的UI,我们命名为 plaza-ui
  • 各种所需要的前置知识,我们命名为 knowledge

其中,前置知识比较繁杂,包含多种知识,每个知识都将以单独项目出现,knowledge 只是用于组织这些单独的项目。

目录结构

我们通过一个 plaza 目录组织本专题所需要的所有项目,如下:

├── plaza
│   ├── knowledge
│   ├── plaza
│   ├── plaza-distributed
│   └── plaza-ui

阶段一的单节点商城

cargo new plaza
  • db:数据操作
  • model:模型定义
  • service:封装业务逻辑
  • form:表单定义
  • handler:axum 处理程序

user(用户)为例,它的结构是:

plaza/plaza
└── src
    ├── user
    │   ├── db
    │   ├── form
    │   ├── handler
    │   ├── model
    │   └── service

除此之外,我们还将中间件(mid)、工具函数(util)单独为一个模块:

plaza/plaza
└── src
    ├── mid
    ├── user
    │   ├── db
    │   ├── form
    │   ├── handler
    │   ├── model
    │   └── service
    └── util

依照以上方案,我们可以为商家(merchant)、订单(order)等其它功能创建对应的模块:

plaza/plaza
└── src
    ├── merchant
    │   ├── db
    │   ├── form
    │   ├── handler
    │   ├── model
    │   └── service
    ├── mid
    ├── order
    │   ├── db
    │   ├── form
    │   ├── handler
    │   ├── model
    │   └── service
    ├── user
    │   ├── db
    │   ├── form
    │   ├── handler
    │   ├── model
    │   └── service
    └── util

前置知识

我们会在 knowledge 目录下,为每个知识点创建一个独立的项目。比如,在讲解『SSE(服务端事件)』知识时,我们会创建sse项目,在讲解『分布式锁』知识时,我们会创建distributed-lock项目:

plaza/knowledge
├── distributed-lock
└── sse

阶段二的分布式商城

我们将依照旧版商城项目的结构进行创建,到时详解。

我们使用 NextJS 来构建 UI,使用的是官方的 create-next-app 命令,并使用 App 路由方式。所以它的结构就是典型的 NextJS 项目结构,具体结构我们到时详解。

整体结构

经过以上讲解,让我们看一下整个专题大概的目录结构:

├── plaza
│   ├── knowledge
│   │   ├── distributed-lock
│   │   └── sse
│   ├── plaza
│   │   └── src
│   │       ├── merchant
│   │       │   ├── db
│   │       │   ├── form
│   │       │   ├── handler
│   │       │   ├── model
│   │       │   └── service
│   │       ├── mid
│   │       ├── order
│   │       │   ├── db
│   │       │   ├── form
│   │       │   ├── handler
│   │       │   ├── model
│   │       │   └── service
│   │       ├── user
│   │       │   ├── db
│   │       │   ├── form
│   │       │   ├── handler
│   │       │   ├── model
│   │       │   └── service
│   │       └── util
│   ├── plaza-distributed
│   └── plaza-ui

开发环境

本专题将在 Linux x64 下进行开发,所以涉及到的某些脚本会使用 GNU 工具链和 Bash 脚本。这些工具基本与 MacOS 兼容,对于 Windows 而言,建议像作者一样,使用 WSL2。

专题所需要的一些服务,比如 PostgreSQL,都是使用 docker ,所以请确保你安装了 docker。

开发工具和插件

本专题使用 Visual Studio Code 进行开发,为了提高开发效率,将使用以下插件:

  • rust-analyzer:使用 VSC 开发 Rust 必备插件,提供自动完成、格式化代码、错误检查等日常开发所需的功能
  • Even Better TOML:提供 TOML 支持
  • Dependi:依赖管理,提供自动检测项目依赖是否有新版本等功能
  • Error Lens:将错误信息直接显示,而不需要移动光标到错误处,再弹出错误信息
  • DotEnv:提供 .env 支持
  • clang-format:格式化 protobuf3 文件
  • vscode-proto3:提供 protobuf3 支持
  • Prettier:对多种文件进行格式化,尤其是前端相关的文件
  • Tailwind CSS IntelliSense:提供 Tailwind CSS 支持。包括自动完成类名,显示类名对应的原生 CSS 等功能
  • Codeium:AI 智能助手,根据上下文提供代码补全
  • Roo Cline:AI 智能助理,通过 chat 自动生成项目。它是 Cline 的 fork 版本,提供比原版更易用的功能
  • REST Client:直接在 VSC 里发起 HTTP 请求,用于 API 测试

源码仓库

本专题代码位于axumrs/plaza仓库,每个涉及代码编写的章节都使用独立的分支。该仓库将公开一段时间,之后将转为私有仓库,请已购买本专题的用户尽快联系我们,提供你的 github 邮箱,我们将把你加入到该仓库中。

要查看完整内容,请先登录