Skip to content

YES-Lee/nestjs-graphql-starter

Repository files navigation

Nestjs + graphql快速开发框架

测试数据库:sql/test.sql

集成了如下技术:

  • ORM:typeorm
  • 接口:graphql
  • 认证:passport
  • 日志工具:nest-pino

开发之前请详细阅读项目中的所有文档(各个目录下的README.md)文件,以及熟悉相关技术中提到的所有技术。

开发

git clone https://github.com/YES-Lee/nestjs-graphql-starter.git # 拉取代码
cd nestjs-graphql-starter
yarn install
yarn start:dev

graphql plaground地址:http://localhost:3000/graphql

项目结构

src
├─ config // 配置模块
├─ database // 数据库模块
│  └─ entities // 存放typeorm/graphql数据库模型
├─ decorators // 自定义装饰器目录
├─ graphql // graphql 模块
├─ enums // 枚举目录
├─ filters // error filters
├─ interceptors // interceptors
├─ pipes // pipes
└─ modules // 业务逻辑模块目录,所有业务相关逻辑都放到该目录对应的模块

所有业务相关的逻辑都应存放于modules目录下,接口按照功能模块划分,通常以表为参考,即一张表(除关系表外)对应一个功能模块。例如:用户相关的功能,应该全部位于/modules/user/目录下。

接口规范(graphql)

graphql类型定义为自动化生成(schema.gql),可以复用database/models下的数据库模型,graphql定义的是http接口层对象,不应该返回的(如:password)等敏感字段,不建议定义grqphql类型

部署

部署app方式有多种,这里提供一个pm2管理方式,有三种部署方式,根据不同场景选择使用

编译部署

  1. 编译:npm run build
  2. 拷贝package.json, pm2.config.jsdist目录(需要修改pm2.config.js文件
  3. dist目录上传到服务器
  4. dist目录执行npm install --production
  5. 启动:pm2 pm2.config.js

仓库部署

  1. 在服务器拉取仓库
  2. npm install
  3. npm run build,
  4. pm2 pm2.config.js

docker部署

相关指令

创建模块

nest g module modules/{your_module_name}

创建服务

nest g service modules/{your_service_name}

创建控制器

nest g controller modules/{your_controller_name}

创建resolver

nest g resolver modules/{your_resolver_name}

相关技术

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published