若是你有PHP 開發經驗,會習慣在修改PHP 腳本後直接刷新瀏覽器以觀察結果,而你
在開發Node.js 實現的HTTP 應用時會發現,不管你修改了代碼的哪一部份,都必須終止
Node.js 再從新運行纔會奏效。這是由於Node.js 只有在第一次引用到某部份時纔會去解析腳
本文件,之後都會直接訪問內存,避免重複載入,而PHP 則老是從新讀取並解析腳本(如
果沒有專門的優化配置)。Node.js的這種設計雖然有利於提升性能,卻不利於開發調試,因
爲咱們在開發過程當中老是但願修改後當即看到效果,而不是每次都要終止進程並重啓。
supervisor 能夠幫助你實現這個功能,它會監視你對代碼的改動,並自動重啓Node.js。
使用方法很簡單,首先使用npm 安裝supervisor:
$ npm install -g supervisor node
若是你使用的是Linux 或Mac,直接鍵入上面的命令極可能會有權限錯誤。緣由是npm
須要把supervisor 安裝到系統目錄,須要管理員受權,可使用 sudo npm install -g
supervisor 命令來安裝。
接下來,使用supervisor 命令啓動app.js:
npm
$ supervisor app.js DEBUG: Running node-supervisor with DEBUG: program 'app.js' DEBUG: --watch '.' DEBUG: --extensions 'node|js' DEBUG: --exec 'node' DEBUG: Starting child process with 'node app.js' DEBUG: Watching directory '/home/byvoid/.' forchanges. HTTP server is listening at port 3000.
當代碼被改動時,運行的腳本會被終止,而後從新啓動。在終端中顯示的結果以下:
編程
DEBUG: crashing child DEBUG: Starting child process with 'node app.js' HTTP server is listening at port 3000. supervisor 這個小工具能夠解決開發中的調試問題。
3.2 異步式I/O 與事件式編程 瀏覽器
supervisor的安裝也很簡單:app
直接用npm安裝既可,鍵入命令: npm -g install supervisor異步
這裏注意一點的就是,supervisor必須安裝到全局,若是你不安裝到全局,錯誤命令會提示你安裝到全局。工具
若是不想安裝到默認的全局,也能夠本身修改全局路徑到當前路徑性能
npm config set prefix "路徑"優化
安裝完之後就能夠用supervisor 來啓動服務了。spa
supervisor app.js
啓動徹底是這個樣子
修改一下,而後刷新