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 相关文章推荐
input+select(multiple) 实现下拉框输入值
May 21 Javascript
javascript 拖放效果实现代码
Jan 22 Javascript
js隐式全局变量造成的bug示例代码
Apr 22 Javascript
js判断上传文件类型判断FileUpload文件类型代码
May 20 Javascript
新手快速学习JavaScript免费教程资源汇总
Jun 25 Javascript
jQuery解决浏览器兼容性问题案例分析
Apr 15 Javascript
详解Vue2.X的路由管理记录之 钩子函数(切割流水线)
May 02 Javascript
vue实现前进刷新后退不刷新效果
Jan 26 Javascript
微信小程序常用的3种提示弹窗实现详解
Sep 19 Javascript
javascript实现蒙版与禁止页面滚动
Jan 11 Javascript
Vue中component标签解决项目组件化操作
Sep 04 Javascript
Vue仿百度搜索功能
Dec 28 Vue.js
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输出当前进程所有变量/常量/模块/函数/类的示例
2013/11/07 PHP
ThinkPHP安装和设置
2015/07/27 PHP
php远程下载类分享
2016/04/13 PHP
PHP面向对象程序设计之对象生成方法详解
2016/12/02 PHP
PHP中使用jQuery+Ajax实现分页查询多功能操作(示例讲解)
2017/09/17 PHP
jQuery find和children方法使用
2011/01/31 Javascript
使用Json比用string返回数据更友好,也更面向对象一些
2011/09/13 Javascript
js限制文本框只能输入数字(正则表达式)
2012/07/15 Javascript
angularJS中$apply()方法详解
2015/01/07 Javascript
Vue.js组件tree实现无限级树形菜单
2016/12/02 Javascript
Vue.js路由vue-router使用方法详解
2017/03/20 Javascript
完美解决浏览器跨域的几种方法(汇总)
2017/05/08 Javascript
Popup弹出框添加数据实现方法
2017/10/27 Javascript
Angular angular-file-upload文件上传的示例代码
2018/08/23 Javascript
vue-auto-focus: 控制自动聚焦行为的 vue 指令方法
2018/08/25 Javascript
服务端预渲染之Nuxt(使用篇)
2019/04/08 Javascript
Vue运用transition实现过渡动画
2019/05/06 Javascript
VueCli4项目配置反向代理proxy的方法步骤
2020/05/17 Javascript
解决js中的setInterval清空定时器不管用问题
2020/11/17 Javascript
[35:26]DOTA2上海特级锦标赛B组小组赛#2 VG VS Fnatic第三局
2016/02/26 DOTA
把JSON数据格式转换为Python的类对象方法详解(两种方法)
2019/06/04 Python
Python datetime 格式化 明天,昨天实例
2020/03/02 Python
python pandas.DataFrame.loc函数使用详解
2020/03/26 Python
解决Pytorch自定义层出现多Variable共享内存错误问题
2020/06/28 Python
python+django+selenium搭建简易自动化测试
2020/08/19 Python
如何向scrapy中的spider传递参数的几种方法
2020/11/18 Python
基于HTML5新特性Mutation Observer实现编辑器的撤销和回退操作
2016/01/11 HTML / CSS
介绍一下SQL注入攻击的种类和防范手段
2012/02/18 面试题
《雾凇》教学反思
2014/02/17 职场文书
校企合作协议书
2014/04/16 职场文书
大学生入党推荐书范文
2014/05/17 职场文书
干部职工纪律作风整改措施思想汇报
2014/10/11 职场文书
公积金具结保证书
2015/05/11 职场文书
大学生社会实践感想
2015/08/11 职场文书
MySQL数据库如何使用Shell进行连接
2022/04/12 MySQL
python 闭包函数详细介绍
2022/04/19 Python