NestJS 微服代码组织

组织代码之前看 NestJS 社区有什么?

  • 具有 workspace 的功能包管理工具 pnpm/yarn/npm 等
  • NestJS CLi 提供的 monorepo 模式
  • Nx 一个全栈管理框架
  • Turbo monorepo 管理工具

以下文章都建立在 pnpm + workspace 基础上, 以 gRPC 为例的微服务。

以 api-gateway 方式暴露 api

此模式的特点是: api-gateway 方式实现 api,但是具体的业务逻辑放在微服务汇总,api-gateway 实现的内容需要通过 gRPC 调用远程微服务函数实现。

特点:

  • 使用 api-gateway 服务对外暴露 api。
  • 使用 微服务 完成业务逻辑。
  • 使用 tcp/gRPC 等在 api-gateway 服务器之间进行通信。
  • 自己就是一整模块功能的实现。

缺点:

  • 功能不单一,有业务聚合性。

进阶:

  • 聚合接口:有些模块不需要实现自己的业务,但是需要对外暴露接口,此需要聚合其他业务的微服务,使得此时开发的层级加深。

一个目录结构:

ts 复制代码
.
├── REAMEME.md
├── package.json
├── packages
│   ├── api-gateway
│   └── ms-user
├── pnpm-lock.yaml
└── pnpm-workspace.yaml

服务与微服务

此模式的特点是:微服务与服务一起对外暴露,服务一般对外暴露 api, 而 微服务一般用来暴露内部通信使用。

特点

  • 自己就是一个 api-gateway,功能专一
  • 一般需要实现两套 api, http api 对外,给 nginx 等方向代理,gRPC 等微服务,对内,提供给其他微服务。

缺点

  • 每一个模块就是一个项目,单人的管理难度增大。

看起来目录结构:

tree 复制代码
.
├── REAMEME.md
├── nginx
│   └── nginx.conf
├── package.json
├── packages
│   ├── ms-link
│   ├── ms-tag
│   └── ms-user
├── pnpm-lock.yaml
└── pnpm-workspace.yaml

管理微服务

启动微服务

使用 pnpm 的平行运行脚本能力

sh 复制代码
{
    "scripts": {
        "dev:be": "pnpm -r --parallel --filter=./packages/* run start:dev",
    }
}

要运行 packages 目录下的所有项目,启动命令是 run start:dev, pnpm 会以颜色作为区分输出不同的醒目的输出内容。

启动具有 debug 功能的微服务

此处以 VS Code 为例,添加 launch.json 文件, 同时还需要在 pnpm 的根目录添加脚本配置

  • 根目录脚本
ts 复制代码
{
    "scripts": {
        "dev:api-gateway": "pnpm run --filter=api-gateway start:dev",
        "dev:ms-user": "pnpm run --filter=ms-user start:dev",
    }
}
  • VS Code 对应的配置
json 复制代码
{
  "version": "0.2.0",
  "configurations": [
    {
      "type": "node",
      "request": "launch",
      "name": "api-gateway",
      "runtimeExecutable": "pnpm",
      "args": ["run", "dev:api-gateway"],
      "skipFiles": ["<node_internals>/**"],
      "console": "integratedTerminal"
    },
    {
      "type": "node",
      "request": "launch",
      "name": "dev:ms-user",
      "runtimeExecutable": "pnpm",
      "args": ["run", "dev:ms-user"],
      "skipFiles": ["<node_internals>/**"],
      "console": "integratedTerminal"
    }
  ]
}

在后就可以在 VS Code 调试中找到配置可选的调试工具了。

小结

本文主要探索了 NestJS 微服代码组织探索,两种模式:一种是 api-gateway 实现业务逻辑,另外一种是全部微服务化使用 nginx 实现反向代理。然后再 VS Code 中实现了启动调试微服务的能力。希望这些探索能够帮助大家。

相关推荐
恋猫de小郭3 分钟前
为什么跨平台框架可以适配鸿蒙,它们的技术原理是什么?
android·前端·flutter
AntBlack5 分钟前
Trae Agent :能提高开发效率的功能都值亲自体验一下
后端·ai编程·trae
云浪6 分钟前
元素变形记:CSS 缩放函数全指南
前端·css
明似水21 分钟前
用 Melos 解决 Flutter Monorepo 的依赖冲突:一个真实案例
前端·javascript·flutter
独立开阀者_FwtCoder31 分钟前
stagewise:让AI与代码编辑器无缝连接
前端·javascript·github
清沫33 分钟前
Cursor Rules 开发实践指南
前端·ai编程·cursor
江城开朗的豌豆38 分钟前
JavaScript篇:对象派 vs 过程派:编程江湖的两种武功心法
前端·javascript·面试
不吃糖葫芦340 分钟前
App使用webview套壳引入h5(二)—— app内访问h5,顶部被手机顶部菜单遮挡问题,保留顶部安全距离
前端·webview
江城开朗的豌豆1 小时前
JavaScript篇:字母侦探:如何快速统计字符串里谁才是'主角'?
前端·javascript·面试
江梦寻1 小时前
MacOS下Homebrew国内镜像加速指南(2025最新国内镜像加速)
开发语言·后端·python·macos·架构·策略模式