Node实战之不同环境下配置文件使用教程


Posted in Javascript onJanuary 02, 2018

前言

在使用 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即可。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
使用JS操作页面表格,元素的一些技巧
Feb 02 Javascript
基于IE下ul li 互相嵌套时的bug,排查,解决过程以及心得介绍
May 07 Javascript
jQuery遮罩层效果实例分析
Jan 14 Javascript
Java遍历集合方法分析(实现原理、算法性能、适用场合)
Apr 25 Javascript
Angularjs 实现一个幻灯片示例代码
Sep 08 Javascript
JavaScript如何一次性展示几万条数据
Mar 30 Javascript
JavaScript 复制对象与Object.assign方法无法实现深复制
Nov 02 Javascript
js replace替换字符串同时替换多个方法
Nov 27 Javascript
vue element动态渲染、移除表单并添加验证的实现
Jan 16 Javascript
electron实现静默打印的示例代码
Aug 12 Javascript
layui复选框限制选择个数的方法
Sep 18 Javascript
VUE子组件向父组件传值详解(含传多值及添加额外参数场景)
Sep 01 Javascript
jQuery动态添加元素无法触发绑定事件的解决方法分析
Jan 02 #jQuery
Node解决简单重复问题系列之Excel内容的获取
Jan 02 #Javascript
node作为中间服务层如何发送请求(发送请求的实现方法详解)
Jan 02 #Javascript
React教程之封装一个Portal可复用组件的方法
Jan 02 #Javascript
Node层模拟实现multipart表单的文件上传示例
Jan 02 #Javascript
10行原生JS实现文字无缝滚动(超简单)
Jan 02 #Javascript
js原生实现移动端手指滑动轮播图效果的示例
Jan 02 #Javascript
You might like
PHP使用者状态管理功能的应用
2006/10/09 PHP
php简单截取字符串代码示例
2016/10/19 PHP
PHP中大括号'{}'用法实例总结
2017/02/08 PHP
Laravel5.7 Eloquent ORM快速入门详解
2019/04/12 PHP
javascript中的location用法简单介绍
2007/03/07 Javascript
漂亮的widgets,支持换肤和后期开发新皮肤
2007/04/23 Javascript
javascript Xml增删改查(IE下)操作实现代码
2009/01/30 Javascript
JavaScript效率调优经验
2009/06/04 Javascript
jquery动画3.创建一个带遮罩效果的图片走廊
2012/08/24 Javascript
JQuery.Ajax之错误调试帮助信息介绍
2013/07/04 Javascript
IE6-IE9中tbody的innerHTML不能赋值的解决方法
2014/09/26 Javascript
javascript中AJAX用法实例分析
2015/01/30 Javascript
js实现正则匹配中文标点符号的方法
2015/12/23 Javascript
微信小程序 this和that详解及简单实例
2017/02/13 Javascript
Vue.js基础学习之class与样式绑定
2017/03/20 Javascript
JS判断两个对象内容是否相等的方法示例
2017/04/10 Javascript
jQuery实现动态给table赋值的方法示例
2017/07/04 jQuery
js实现移动端导航点击自动滑动效果
2017/07/18 Javascript
js判断文件类型大小并给出提示的实现方法
2018/01/03 Javascript
VUEJS 2.0 子组件访问/调用父组件的实例
2018/02/10 Javascript
对Vue2 自定义全局指令Vue.directive和指令的生命周期介绍
2018/08/30 Javascript
swiper4实现移动端导航切换
2020/10/16 Javascript
layui的表单提交以及验证和修改弹框的实例
2019/09/09 Javascript
Vue中axios拦截器如何单独配置token
2019/12/27 Javascript
python通过yield实现数组全排列的方法
2015/03/18 Python
Python搭建APNS苹果推送通知推送服务的相关模块使用指南
2016/06/02 Python
Python HTTP客户端自定义Cookie实现实例
2017/04/28 Python
python实现感知机线性分类模型示例代码
2019/06/02 Python
将matplotlib绘图嵌入pyqt的方法示例
2020/01/08 Python
铭立家具面试题
2012/12/06 面试题
大学军训通讯稿
2014/01/13 职场文书
求职意向书
2014/04/01 职场文书
竞选劳动委员演讲稿
2014/04/28 职场文书
操行评语大全
2014/04/30 职场文书
早会开场白台词大全
2015/06/01 职场文书
AJAX实现省市县三级联动效果
2021/10/16 Javascript