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

相关文章

mybatis映射器配置小结

《mybatis映射器配置小结》本文详解MyBatis映射器配置,重点讲解字段映射的三种解决方案(别名、自动驼峰映射、resultMap),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定... 目录select中字段的映射问题使用SQL语句中的别名功能使用mapUnderscoreToCame

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映