1

我陷入了一种我想同步两个 mongoDB 的情况,一个在本地机器上,第二个在远程机器上(在 mlab 沙箱上)。对于同步,我正在做:

首先,我使用 mongodump 转储具有更改的集合,然后使用 mongorestore 我在远程 MongoDB 上恢复该集合。

但是我面临两个问题。

首先是如何更新远程 mongoDB 上的集合。例如:在更改集合时,我应该替换远程端的整个集合还是使用其他方式?以及这样做的最佳方法是什么。

第二个问题是如何检测集合中的变化。或在整个数据库中。我正在使用环回框架和事件流 npm 模块将更改发送到客户端。但我无法在服务器端读取更改流。

我的 server\boot\realtime.js 是:

var es = require('event-stream');
var sync = require('../sync');

module.exports = function(app) {

  var completeOrder = app.models.completeOrder;

  completeOrder.createChangeStream(function(err, changes) {

   sync('completeOrder',function(data){

      console.log(data);
    },function(err){

      console.log(err);
    });
   changes.pipe(es.stringify()).pipe(process.stdout);
  });

}
4

1 回答 1

0

在第二个问题上,当底层数据库中的数据发生变化时,LoopBack 不会发送事件,而只会在模型发生变化时发送事件。Mongo 3.6 提供更改流功能,您可以使用它来触发模型更改/执行您的功能。

于 2017-12-09T12:55:47.957 回答