使用Node如何配置文件(详细教程)

 我来答
懂视生活
2023-07-27 · 百度认证:湖南福仁科技有限公司官方账号
懂视生活
向TA提问
展开全部

这篇文章主要给大家介绍了关于Node实战之不同环境下配置文件使用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面一起学习学习吧。
前言
在使用 Node.js 编写一个完整的项目时,程序中往往需要用到一些可配置的变量,从而使得程序能在不同的环境中运行,而众所周知,在实际的项目会存在多个不同的环境,不同的环境下,一些配置是不相同的,如何在不同的环境下调用不同的配置,提高开发效率?下面话不多说了,来一起看看详细的介绍吧。
1. config-lite模块
首先引入一个配置模块config-lite,使用命令npm i config-lite --save安装。
通常我们会针对不同的环境,将配置写入不同的配置文件中,在Node项目下新建config目录,里面新建不同环境的配置文件,这里我以『开发』以及『生产』两个环境作为例子来讲解如何操作。
开发环境中,我们在config目录下新建两个文件:test.js和default.js,你可能会问,为啥没有生产机配置文件,因为生产机配置要在生产环境下再创建嘛。
在test.js配置文件中写入代码如下(PS. 这里以mysql的配置为例):
// test.js
module.exports = {
mysql : {
host: "localhost",
user: "lupeng",
password: "080910",
database: "b1imd"
}
};default.js里写入一些默认的配置文件,例如session的配置等。
// default.js
module.exports = {
mysql : {
host: "10.20.141.220",
user: "lupeng",
password: "123456",
database: "b1imd"
},
session: {
secret: 'keyboard cat',
resave: false,
saveUninitialized: true,
cookie: {
maxAge: 1000*60*60
}
}
};好了,配置文件写好了,如何使用呢?这里我们使用的 config-lite模块,这个模块是依据环境变量来选择不同的配置文件的,所以在使用之前我们需要修改package.json里的启动命令:
"scripts": {
"start": "NODE_ENV=production supervisor --harmony -i views/ ./bin/www",
"test": "NODE_ENV=test supervisor --harmony -i views/ ./bin/www"
},可以看到,上面有两条启动命令,一条是针对生产机,设置了NODE_ENV=production,一条是针对测试机,设置了NODE_ENV=test,当我们使用npm test启动项目的时候,config-lite会去抓取test.js配置,并且会与default.js里配置去合并,如果有相同的对象,会覆盖default.js里的配置。如上例子都有mysql的对象,那么这里会以test.js里的对象为准。
好了,下面来介绍一下如何在项目中使用config-lite模块,在app.js里代码如下:
// 省略...
var config = require('config-lite')(__dirname);
// 省略...
app.use(session(config.session));
console.log("mysql服务器:" + config.mysql.host); // display mysql-config
// 省略...引入之后,可以直接使用配置文件中的配置对象。
2. 生产环境
那么在生产环境中,如何使用呢?上面已经介绍了config-lite基本原理以及用法,在生产环境的时候,我们只需要在生产机环境中config目录下新建production.js文件,然后使用启动命令npm start即可。
为了避免测试环境以及生产坏境配置文件混淆,可以通过.gitignore文件忽略配置文件,添加如下:
# config
config/*
!config/default.*这样,git会忽略除了default.js之外的配置文件,在本地开发环境中,可以创建多个配置文件测试使用,只需设置对应的环境变量即可。需要注意的是环境变量名需同配置文件名一样。
3. windows环境
也许你是一个多系统环境开发者,可能同时在Linux和windows环境下开发,由于windows下设置环境的变量的语法不太一样,所以可以在package.json启动命令中再加上两句,如下:
"scripts": {
"start": "NODE_ENV=production supervisor --harmony -i views/ ./bin/www",
"test": "NODE_ENV=test supervisor --harmony -i views/ ./bin/www",
"winStart": "SET NODE_ENV=production&&supervisor --harmony -i views/ ./bin/www",
"winTest": "SET NODE_ENV=test&&supervisor --harmony -i views/ ./bin/www"
}这样,如果部署在windows环境下,在config目录下新建production.js配置文件,启动命令npm winStart;如果部署在Linux或类Unix环境下,同样是创建production.js,启动命令npm start即可。
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
详细解读React Native Flexbox布局
在vue单文件中有关引用路径有哪些方法?
详细介绍有关weex中的webpack.config.js改造
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式