- 支持试读
内容简介
本章将带你了解本专题的整体内容。 - 支持试读
项目结构
本专题相对复杂,规划好结构非常必要。本专题至少包含四大部分:阶段一的单节点商城、阶段二的分布式商城、商城的UI和各种所需要的前置知识。 阶段一开篇:用户注册与激活
本章我们将开启本专题的旅程,既是阶段一的开篇,也是整个专题的开篇。本章我们将实现用户注册和激活功能。本章涉及两个数据模型:用户和激活码,同时还涉及邮件发送和人机验证。对于激活码,我们将使用 PostgreSQL 的某些特性来代替 Redis。前置知识:AXUM中间件
我们曾在《漫游AXUM》专题中讲解过中间件,随着版本迭代,AXUM中间件的机制发生了很大的改变。本章我们将基于当前最新版本的AXUM,讨论各种类型的中间件的实现以及如何在 handler 中,获取中间件里的数据。
项目结构
- 34
- 2025-01-19 10:07:26
本专题相对复杂,规划好结构非常必要。本专题至少包含四大部分:阶段一的单节点商城、阶段二的分布式商城、商城的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 邮箱,我们将把你加入到该仓库中。