PouchDB 同步没有给出完整的事件

PouchDB sync not giving a complete event

我的 PouchDB 同步代码没有生成完整的事件。

我确实收到了更改、活动和暂停事件(按此顺序),并且数据库最终同步了(经过很长时间的等待,即使数据不多)。

我需要完整的事件,以便我知道远程 CouchDB 数据何时在本地可用。

我的代码如下所示:

  init(localDBName, remoteDBName)
  // Initialises the database - Called every time the App starts or the user logs in or registers
  // If remoteDBName is false we don't want to sync data to the server
  {

    // Create a new database or open it if it already exists
    this._DB = new PouchDB(localDBName);
    this.remote = remoteDBName;          // If remoteDBName is false we don't sync data to the server

    console.log('Data: init(): PouchDB database opened for localDBName = ' + localDBName + ' : ' + this._DB + ', remoteDBName = ' + this.remote);

    // Sync to remote DB if we have been asked to
    if (this.remote)
    {
      // Insert the url for the CouchDB server into the remoteDBName returned by PouchDB
      var realRemoteDB = this.remote.replace("localhost:5984", COUCHDB_SERVER_URL);

      console.log('Data: init: remoteDB path being used is: ' + realRemoteDB);

      let options = {
        live: true,
        retry: true,
        continuous: true
      };

      return this._syncHandler = this._DB.sync(realRemoteDB, options)
        .on('complete', (info) => {
          console.log('***** DATA: init() Complete: Handling syncing complete');
          console.dir(info);
        })
        .on('change', (info) => {
          console.log('***** DATA: init() Change: Handling syncing change');
          console.dir(info);
        })
        .on('paused', (info) => {
          console.log('***** DATA: init() Paused: Handling syncing pause');
          console.dir(info);
        })
        .on('active', (info) => {
          console.log('***** DATA: init() Active: Handling syncing resumption');
          console.dir(info);
        })
        .on('error', (err) => {
          console.log('***** DATA: init() Error: Handling syncing error');
          console.dir(err);
        })
        .on('denied', (err) => {
          console.log('***** DATA: init() Denied: Handling syncing denied');
          console.dir(err);
        });
    }
    else {
      this.syncHandler = null;
    }
  }

我得到的最后一个事件是暂停事件,它在更改事件显示数据已从服务器中提取后立即触发。

这实际上是它应该工作的方式 ;)

sync 方法的行为因您指定的选项而异:

  • 没有live选项:在正常的同步中(没有live选项)complete事件将就像你想象的那样工作:它会在同步完成后触发。

  • 使用 live 选项:在实时 replication/synchronisation 中,同步永远不会完成,因为它是连续的。 complete 事件只有在复制被取消时才会被触发。请参阅文档 here(我突出显示了重要部分):

    complete (info) - This event fires when replication is completed or cancelled. In a live replication, only cancelling the replication should trigger this event.


要解决您的问题,您最初可以在不使用 live 选项的情况下进行同步。如果此同步完成,您的远程数据应该在本地可用。

现在在 complete 事件处理程序中,您可以启动实时复制以开始连续同步。

代码可能如下所示:

this._DB.sync(realRemoteDB) //No options here -> One time sync
        .on('complete', (info) => {              
          this._DB.sync(realRemoteDB, options); //Continous sync with options
        });