目的
開發(fā)中監(jiān)聽文件修改滩租,達(dá)到重啟node等項目服務(wù)的作用栽渴,減少手動執(zhí)行:[Ctrl-C] [Up-Arrow] [Enter]算途。使用nodemon代替node去啟動項目服務(wù)履婉,nodemon [your node app](相當(dāng)于 node [your node app]),監(jiān)聽進(jìn)程宣羊。
安裝
npm install -g nodemon
使用
命令行模式
nodemon --ignore dist/ --ignore node_modules/ --watch src -C -e js,json,css,scss,vue --debug -x "npm run build"
配置文件模式
nodemon --config nodemon.json -x "npm run build"
// nodemon.json
{
"restartable": "rs",
"ignore": [
"dist",
"node_modules/**/node_modules",
],
"verbose": true,
"execMap": {
"js": "node --harmony"
},
"events": {
"restart": "osascript -e 'display notification \"App restarted due to:\n'$FILENAME'\" with title \"nodemon\"'"
},
"watch": [
"src",
],
"env": {
"NODE_ENV": "development"
},
"ext": "js,json,css,scss,vue"
}
命令行優(yōu)先級高于配置文件璧诵,命令行模式中的參數(shù)設(shè)置會覆蓋掉配置文件的參數(shù)配置。
參數(shù)說明
restartable:重啟的命令仇冯,默認(rèn)是 rs 之宿,可以自定義字符串。當(dāng)用 nodemon 啟動應(yīng)用后苛坚,在監(jiān)聽窗口直接輸入rs 可直接重啟服務(wù)比被,不需要停止服務(wù)在重啟。除了字符串值外泼舱,設(shè)置為 false 則不會在 nodemon 運行期間監(jiān)聽 rs 的重啟命令等缀,避免影響了其他終端命令。
ignore:忽略的文件后綴名或者文件夾娇昙,文件路徑的書寫用相對于 nodemon.json 所在位置的相對路徑项滑。nodemon 默認(rèn)忽略的文件有:.git, node_modules, bower_components, .sass-cache,如果這些文件想要加入監(jiān)控涯贞,需要重寫默認(rèn)忽略參數(shù)字段 ignoreRoot,比如加入:"ignoreRoot": [".git", "bower_components", ".sass-cache"]危喉,然后在 watch 中將 node_modules 文件路徑加入監(jiān)控宋渔,那么 node_modules 內(nèi)的文件也加入了監(jiān)控。
verbose:true 表示輸出詳細(xì)啟動與重啟信息辜限,默認(rèn)false不輸出皇拣。
$ nodemon --config 'nodemon.json' -x 'npm run build'
[nodemon] 2.0.19
[nodemon] reading config ./nodemon.json
[nodemon] to restart at any time, enter `rs`
[nodemon] or send SIGHUP to 39624 to restart
[nodemon] ignoring: node_modules/**/node_modules ./dist/**/*
[nodemon] watching path(s): src/**/*
[nodemon] watching extensions: js,json,css,scss,vue
[nodemon] bind restart -> `osascript -e 'display notification "App restarted due to:
'$FILENAME'" with title "nodemon"'`
[nodemon] starting `npm run build`
[nodemon] spawning
[nodemon] child pid: 39626
[nodemon] watching 409 files
execMap:運行服務(wù)的后綴名和對應(yīng)的運行命令,"js": "node --harmony" 表示用 nodemon 代替 node --harmony 運行 js 后綴文件薄嫡;"": "node" 指 www 這些沒有后綴名的文件氧急;默認(rèn)的 defaults.js 配置文件會識別一些文件:py: 'python',rb: 'ruby'。
events:表示 nodemon 運行到某些狀態(tài)時的一些觸發(fā)事件毫深,總共有五個狀態(tài):
start - 子進(jìn)程(即監(jiān)控的應(yīng)用)啟動
crash - 子進(jìn)程崩潰吩坝,不會觸發(fā) exit
exit - 子進(jìn)程完全退出,不是非正常的崩潰
restart - 子進(jìn)程重啟
config:update - nodemon 的 config 文件改變
狀態(tài)后面可以帶標(biāo)準(zhǔn)輸入輸出語句哑蔫,比如 mac 系統(tǒng)下設(shè)置: "start": "echo 'app start'"钉寝,那么啟動應(yīng)用時會輸出 app start 信息弧呐。除此之外,也可以寫js來監(jiān)控嵌纲,github 上有介紹: events.md(https://github.com/remy/nodemon/blob/master/doc/events.md)俘枫。
macos神器osascript可以顯示桌面通知,語法如下:
osascript -e ' display notification "通知內(nèi)容" with title "標(biāo)題" subtitle "子標(biāo)題" '
watch:監(jiān)控的文件夾路徑或者文件路徑逮走。
env:運行環(huán)境 development 是開發(fā)環(huán)境鸠蚪,production 是生產(chǎn)環(huán)境,port 是端口號师溅。
ext:監(jiān)控指定后綴名的文件茅信,用逗號間隔。默認(rèn)監(jiān)控的后綴文件:.js, .coffee, .litcoffee, .json险胰。
注:關(guān)于監(jiān)控以及忽略文件修改有個順序的問題汹押,或者說優(yōu)先級,首先 nodemon 會先讀取 watch 里面需要監(jiān)控的文件或文件路徑起便,再從文件中選擇監(jiān)控 ext 中指定的后綴名棚贾,最后去掉從 ignore 中指定的忽略文件或文件路徑。
總結(jié)
進(jìn)程管理工具除了nodemon外榆综,還有forever妙痹,supervisor,pm2等鼻疮,他們對比鏈接怯伊,有興趣可以閱讀,開發(fā)中nodemon還是比較合適判沟,生產(chǎn)的話用pm2會更好些耿芹。
另外,官方也有整理出一些常見問題:https://github.com/remy/nodemon/blob/master/faq.md