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

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom