一. 开启 原生 pomelo 的hotreload支持
pomelo版本: 2.2.5 , 编辑脚本 app.js 加入如下代码
//全局配置 app.configure('production|development', function() { //让所有服务器 都支持 handle 和remote 热更新 let serverConfig = { 'reloadHandlers':true, 'reloadRemotes':true, }; app.set('serverConfig',serverConfig); });
原理:监听文件改动,在文件变化以后重新加载,只能更新 remote rpc 和 handler
//监听 handler var watchHandlers = function(app, handlerMap) { var p = pathUtil.getHandlerPath(app.getBase(), app.serverType); if (!!p){ fs.watch(p, function(event, name) { if(event === 'change') { handlerMap[app.serverType] = Loader.load(p, app); } }); } };
注意: 在 remote和handler 文件里不要保存局部数据,否则刷新以后会丢失.
二 .使用bearcat 热更新
根据 treasures 配置好 context.json
{ "name": "bearcat", "scan": "app", "beans": [] }
scan 就是要检测的目录 .
修改app.js,添加如下内容
//BEARCAT_HOT 一定要配置成 on //BEARCAT_LOGGER 如果不关闭,则pomelo的日志输出 会将所有的日志都输出到 pomelo-undefined.log 里面. var contextPath = require.resolve('./context.json'); bearcat.createApp([contextPath], { BEARCAT_HOT: 'on',// 开启热更新,如果是off 那么不会热更新 BEARCAT_LOGGER: 'off',//setup 'off' to turn off bearcat logger configuration, } );
// 启动APP // app.start(); bearcat.start(function() { app.set('bearcat', bearcat); // start app app.start(); });
通过上面简单的操作,bearcat 就已经配置好了.试一试修改文件,控制台就会有提示bearcat重新加载.
三. bearcat更新示例
entryHandler.js
Handler.prototype.enter = function (msg, session, next) {
//这行如果写在函数外面,则不能热更新,每次修改文件要生效,都必须重新加载文件
var Student = require('./student');
var _stu = new Student();
_stu.say();
next(null,0);
return;
}
student.js
var Student = function(){
}
Student.prototype.say = function(){
console.log("i am old say");
console.log("i am old say");
console.log("i am old say");
console.log("i am old say");
}
module.exports = function(){
return new Student();
}
测试过程:
- 开启服务器 node app.js
- 调用 connector.entryHandler.enter , 会打印 i am old say
- 修改 i am old say ==> i am new say
- 控制台输出正在 reload ,等待reload 完毕.
- 调用 connector.entryHandler.enter , 会打印 i am new say
注意:
这行如果写在函数外面,则不能热更新,每次修改文件要生效,都必须重新加载文件 var Student = require('./student');
说明 bearcat 更新主要是更新 新创建的对象! 以前的对象是使用以前的代码,这种情况是更新不了的!