无法在多个集合mongodb上创建监视

时间:2020-10-13 13:36:07

标签: node.js mongodb mongoose changestream

我正在尝试使用mongoose构造

在MongoDB中的数据库集合上创建手表
collection.watch({ fullDocument: "updateLookup" })

我的整个功能如下
exports.createWatchOnAuthCollection = (site, type) => {
    if (watchedTypes.includes(type + '_' + site)) {
        console.log('Ignoring.. Already watch added on this type and site ' + type + '_' + site);
        return;
    }
    dbConnectionPool.getDBConnection('auth_' + site, function (dbConnection) {
        if (type == 'unit_status') {
            console.log('Trying to add watch on ' + site);
            var collection = dbConnection.collection('units');
            collection.watch({
                fullDocument: "updateLookup"
            })
                .on('change', function (change) {
                    handleStatusUpdate(site, change);
                })
                .on('error', function (error) {
                    console.log('Got a error reply')
                });
            watchedTypes.push(type + '_' + site);
        } else if (type == 'iatas') {
            
        }
    });
}

我面临的问题是,当我循环执行此函数调用以在多个集合上创建监视时,实际上只有在最新创建的集合上的监视才起作用,并且调用了回调,但在其他集合上却没有。我的调用功能如下

sites.forEach(site => {
    controller.createWatchOnAuthCollection(site, watchType);
})

预先感谢..:)

1 个答案:

答案 0 :(得分:1)

您不能使用同一会话来创建多个变更流侦听器。因此,您需要指定不同的会话或使用不同的连接来打开每个流。

还要注意,同时打开多个流可能会对性能产生负面影响,因此建议仅在dbconnection对象上打开一个流,并过滤出要监视的集合。例如:

...
collections = [];
sites.forEach(site => {
  // For each collection to watch, add a filter in the collections array
  collections.push({ "db": "auth_" + site, "coll": "units" });
});

// Create a change stream on the deployment and filter only
// the collections we want
client.watch([ { "$match": { "ns": { "$in": collections } } } ],
    { "fullDocument": "updateLookup" });
...