Skip to content

Latest commit

 

History

History
89 lines (55 loc) · 2.94 KB

Forever源码阅读.md

File metadata and controls

89 lines (55 loc) · 2.94 KB
layout title
default
{"site.name" => nil}

Forever源码阅读

forever是一个用来在服务器端一直运行nodejs项目的npm的模块。自己开始尝试尝试读源码,所以会比较细致一点。

先从目录结构开始看

.tracis.yml

这是个用了travis ci管理的项目。申明了运行环境,包括nodejs的几个版本,这里跑的test使用的vows。vows也是一个测试工具,与mocha类似,但是貌似不如mocha的使用.

.jshintrc

这个文件是定义了jshint的格式,主要是用来规范编程风格的,配置了之后直接jshint加上想要查看的文件就行了

.editconfig

也是用来标注项目文件的格式的,可以在sublime或者webstorm中安装插件来支持这个文件,现在支持的格式不多,也就缩进,tab空格而已

.gitignore

这个就是github的规范了,添加了的文件就不会被提交到仓库中

package.json

这个文件是npm的配置,主要是bin这个配置,可以在安装后,使用命令时调用对应的js文件。

其他的几个文件的作用就不解释了

bin文件夹

先看这个文件夹下面

forever文件

提供了bin的窗口,就是调用了lib文件夹下面的cli.js

monitor文件

todu:还没看

lib文件夹

forever文件

todu:还没看

forever文件夹

cli.js

主入口,先引用了一些npm的包。

colors来在nodejs命令行里面打有颜色的log用的。

cliff是用来将数据进行格式化的,提供了输出到命令行中的接口,本身依赖了colors

path-is-absolute是用来判断传入的路径是不是绝对地址的,用来判断当前环境是windows还是linux。

flatiron这个是用来配置并且创建app的,包括浏览器端的app,包括命令行端的,这里主要使用了命令行端的。

shush这个是用来引入包含了注释的json的,这样引入的json可以包含//

prettyjson这个是用来在命令行输出比较好看的json的,也依赖了colors等等。

clone这个是用来复制对象的。

object-assign是用来赋值的,可以将对象的相同属性替换掉,现在作为es6的pollfill了。

然后引用了lib下的forever文件。

然后申明了帮助列表,通过flatiron初始化了app,申明了action,声明了action的参数。

使用flatiron的方法将app的命令行参数以及帮助文档初始化。

app.use(flatiron.plugins.cli, {
  argv: argvOptions,
  usage: help
});

然后申明了一个内部方法tryStart,用来转换路径,尝试唤起

申明了一个updateConfig用来更新forever的配置

申明了一个checkColumn来j检测name是否存在

然后抛出了一个getOptions方法

getOptions方法

传入了file文件,先通过path-is-absolute来判断是不是绝对的路径,不是的话就通过path将路径拼装一下,使用process.cwd()得到路径。

worker.js

todu:还没看