tags: [nodeJS,mvc,sails]
项目搭建
背景介绍
- 最近公司需要开发CMDS系统,公司现有的开发人员都是以JAVA为主,而目前市场上node比较火,而公司前段人员学习java的成本较大,于是乎就想用nodeJS开发项目,并且作为公司技术储备
项目介绍
- 项目使用nodeJS作为开发语言
- MVC框架使用sails
第一步:环境搭建
- 安装node环境
- 安装sails框架
$ npm install sails -g
- 针对已安装node环境的,先检查node版本,如果版本过低的话建议更新到最新版本,防止给自己挖不必要的坑
[root@test003 src]# npm -version # 查看node版本
3.10.10 # 版本过低,需要更新
安装n模块用于更新node版本
[root@test003 src]# npm install -g n # 安装n模块用于更新node版本
/usr/local/node/bin/n -> /usr/local/node/lib/node_modules/n/bin/n
/usr/local/node/lib
└── n@2.1.8
更新node版本
[root@test003 src]# n stable # 更新node版本
install : node-v9.8.0
mkdir : /usr/local/n/versions/node/9.8.0
fetch : https://nodejs.org/dist/v9.8.0/node-v9.8.0-linux-x64.tar.gz
######################################################################## 100.0%
installed : v6.11.2
上一步虽然提示安装了v9.8.0,但是并没有安装成功
尝试命令 ”n + 版本号“后也不成功
[root@test003 src]# n v8.10.0
install : node-v8.10.0
mkdir : /usr/local/n/versions/node/8.10.0
fetch : https://nodejs.org/dist/v8.10.0/node-v8.10.0-linux-x64.tar.gz
######################################################################## 100.0%
installed : v6.11.2
从输出信息看已经安装了v8.10.0,但是并没有在系统在应用安装的最新版本
用which 查看当前系统使用的npm命令在哪?
[root@test003 src]# which npm
/usr/local/node/bin/npm
1、原来是环境变量中配置了node的路径,在/etc/profile.d/node.sh 文件中
2、更改成安装的新版本目录即可:/usr/local/n/versions/node/9.8.0
3、使用命令”source /etc/profile.d/node.sh“更新环境变量
第二步:创建第一个sails项目
- 创建一个CDMS-APP
$ sails new cdms-app
- 创建成功可以看到如下信息
info: Created a new Sails app `cdms-app`!
- 进入项目目录并启动项目
$ cd cdms-app
$ sails lift
- 访问项目地址
localhost:1337
- 不使用sail是启动项目,可以通过app.js启动
$ node app.js
项目结构介绍
- sails结构介绍
第三步:创建一个MVC-DEMO
- 项目创建好了,可以访问后,我们需要创建api接口
创建MOdel层
- 模型文件定义到/api/models中,由Waterline驱动,所有model都能全局访问。Sails提供命令行创建model的命令:$ sails generate model MODEL_NAME
创建View层
- 实现在/views中,除了默认提供的ejs模版引擎之外,还能更换成jade、handlebars等模版引擎
创建Controller层
- 在/api/controller目录里,Sails中提供创建controller的命令:$ sails generate controller CONTROLLER_NAME。
- Sails也提供同时创建model和对应的Controller的命令:
$ sails generate api API_NAME。
- 此时可以看到api目录下已经创建好了对应的controller.js和model.js文件
Sails路由简介
- sails的路由称为蓝图(blueprint)
- blueprint主要要分为三种:RESTful routes、Shortcut routes、Action routes
- 当然Sails也会提供自定义的路由,用户可以在config/blueprints.js和config/polices.js这两个配置文件中选择关闭或者打开blueprint提供的路由,和定义自己的路由。
Sails日志简介
- Sails提供了一个全局对象sails.log用来处理日志信息的输出,日志是分level的,在config/log.js中配置日志输出的level
node项目遇到异常,容易崩溃,导致服务停止
使用forever进程自动重启node服务
- 安装forever
npm install forever -g
- 启动服务
[root@test003 CMDB]# forever start app.js
warn: --minUptime not set. Defaulting to: 1000ms
warn: --spinSleepTime not set. Your script will exit if it does not stay up for at least 1000ms
info: Forever processing file: app.js
- 查看forever守护的服务
[root@test003 CMDB]# forever list
info: Forever processes running
data: uid command script forever pid id logfile uptime
data: [0] en9U /usr/local/n/versions/node/9.8.0/bin/node app.js 12433 12439 /root/.forever/en9U.log 0:0:2:19.592
- 查看日志
forever -o out.log -e err.log app.js