Nestjs框架: 多环境参数配置

2024-02-23 21:12

本文主要是介绍Nestjs框架: 多环境参数配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

多环境配置方案比较:dotenv vs config


1 )dotenv库

  • npmjs.com/package/dotenv
  • 应用广泛,前后端, 解析.env文件,挂载到 process.env 属性上去
  • 安装:$ npm i -S dotenv
  • 按照官方示例配置
  • 在.env文件上配置,对嵌套的数据不太友好,需要自行处理

2 )config库

  • npmjs.com/package/config

  • nodejs环境读取配置文件的包

  • 如果想要支持 .yaml 文件,则需要安装 js-yaml 库来进行支持

  • 对嵌套文件支持友好

  • 新建config/default.json文件, 支持嵌套结构

    {"x":1 ,"y": {"ss":"2"}
    }
    
  • 用法

    const config = require('config')
    const yConfig = config.get('y')
    
  • 进阶用法

    • 合并不同环境的配置
    • 新建 config/production.json
    • 如果在 production 环境下,它会自动合并 default.json 中的配置数据
  • 同样的,支持 yaml 格式, 这里是 defautl.yaml

    # default.yaml
    token: xxxx
    db: host: 'localhost'port: 2222
    
    • 下面是procuction.yaml
      db: host: 'yourdomain.com'port: 2222
      
    • 同样能够解析出来
  • 平时用的时候,也安装下 cross-env, 在package.json中的 scripts

    scripts: {'dev': 'cross-env NODE_ENV=development node index.js''prod': 'corss-env NODE_ENV=production ndoe index.js'
    }
    
    • 这样可以 根据环境来读取对应的yaml配置
  • 注意,以上不仅可以在Nodejs中使用,在前端框架中也可以使用

Nest官方方案:使用config设置配置模块


1 )@nestjs/config 这个模块内置的是 .dotenv

  • 安装:$ npm i -S @nestjs/config

  • 新建 .env文件,配置一些常用的配置

  • 在 app.module.ts 中配置,在这里配置后,相关 controllers 和 providers 都可以使用

    import { ConfigModule } from '@nestjs/config'@Module({// forRoot() 方法就是读取根目录下的 .env 文件imports: [ConfigModule.forRoot(isGlobal: true), UserModule]
    })
    
  • 注意,如果 import { ConfigService } from '@nestjs/config' 直接在UserModule之类的模块中使用,会报错

  • 需要作为一个 @Module 的部分,也就是新建一个user.module.ts文件在@Module中设置 imports 添加一个ConfigModule.forRoot()

  • 之后在user.conftroller.ts 中才能正常使用

  • 正常来说,如果不使用 isGlobal 配置,就会出现如上问题,所以可以在如上的代码示例中,也就是 app.module.ts 中使用

  • 全局配置是推荐的,不建议在每个模块中单独使用

  • 通常 .env 中配置的都是字符串,我们会单独定义一个 enum 枚举的文件来对应读取

  • 这样我们就不用在关键代码中修改字符串了

2 )嵌套 yaml 文件读取

  • 需要使用 js-yaml 库来支持

  • 新建 config/config.yaml

    db:mysql1:host: 127.0.0.1name: mysql-devport: 3306mysql2:host: 127.0.0.1name: mysql-dev1port: 3306
    
  • 新建 src/configuration.ts

    import { readFileSync } from 'fs'
    import * as yaml from 'js-yaml'
    import { join } from 'path'const YAML_CONFIG_FILENMAE = 'config.yaml'
    const filePath = join(__dirname, '../config', YAML_CONFIG_FILENMAE)// 使用函数来导出,因为 ConfigModule 中有一个load方法,需要导入一个函数
    export defualt () => {return yaml.load(readFileSync(filePath, 'utf8'))
    }
    
  • 使用,在 app.module.ts 中

    import { ConfigModule } from '@nestjs/config'
    import { Module } from '@nestjs/common'
    import { UserModule } from './user/user.module'
    import Configuration from './configuration'// const envFilePath = `.env.${process.env.NODE_ENV || 'development'}`@Module({imports: [ConfigModule.forRoot({isGlobal: true,// envFilePath,load: [Configuration]}),UserModule,]
    })
    
  • 这样,在user.controller.ts中 就可以读取到配置文件了

  • 有了这些东西,我们就可以扩展用法了

    • 新建 config/config.production.yml
    • 新建 config/config.development.yml
  • 这样,公共的配置,放在 config.yml 文件中,使用 _.merge 来合并两个配置

  • 分环境来分别配置,后续读取的时候,还是基于process.env.NODE_ENV 来读取对应的配置数据

第三方库config读取json文件配置


1 ) 安装

  • $ npm i -S config

2 ) 配置

  • $ mkdir config
  • $ vi config/default.json
  • $ vi config/development.json
  • $ vi config/production.json
    // default.json
    {"database": {"host": "localhost","port": 3306}
    }// development.json
    {"database": {"dbname": "dev","username": "root","password": "root"}
    }// ...
    

3 )使用

// app.module.ts
import * as config from 'config'console.log(config.get('database')) // 就可以使用了

再结合环境使用,npm i -D cross-env, 结合 package.json

scripts: {"start": "cross-env NODE_ENV=development node dist/index.js"
}

基本用法就是如上

进阶用法参考:github.com/node-config/node-config

还有一个库:github.com/nestjsx/nestjs-config

这篇关于Nestjs框架: 多环境参数配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/739939

相关文章

售价599元起! 华为路由器X1/Pro发布 配置与区别一览

《售价599元起!华为路由器X1/Pro发布配置与区别一览》华为路由器X1/Pro发布,有朋友留言问华为路由X1和X1Pro怎么选择,关于这个问题,本期图文将对这二款路由器做了期参数对比,大家看... 华为路由 X1 系列已经正式发布并开启预售,将在 4 月 25 日 10:08 正式开售,两款产品分别为华

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

SpringQuartz定时任务核心组件JobDetail与Trigger配置

《SpringQuartz定时任务核心组件JobDetail与Trigger配置》Spring框架与Quartz调度器的集成提供了强大而灵活的定时任务解决方案,本文主要介绍了SpringQuartz定... 目录引言一、Spring Quartz基础架构1.1 核心组件概述1.2 Spring集成优势二、J

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle

如何配置Spring Boot中的Jackson序列化

《如何配置SpringBoot中的Jackson序列化》在开发基于SpringBoot的应用程序时,Jackson是默认的JSON序列化和反序列化工具,本文将详细介绍如何在SpringBoot中配置... 目录配置Spring Boot中的Jackson序列化1. 为什么需要自定义Jackson配置?2.

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

Spring中配置ContextLoaderListener方式

《Spring中配置ContextLoaderListener方式》:本文主要介绍Spring中配置ContextLoaderListener方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录Spring中配置ContextLoaderLishttp://www.chinasem.cntene

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优