PouchDB - Синхронизация

Вы можете синхронизировать базы данных, хранящиеся локально в PouchDB, с базами данных, хранящимися в CouchDB. В предыдущей главе мы увидели, как реплицировать базы данных с помощью PouchDB. Там мы использовали методPouchDB.replicate(source, destination).

В дополнение к этому, мы также можем реплицировать данные из локальной базы данных в удаленную базу данных и из удаленной базы данных в локальную базу данных, используя replicate.to() и replicate.from() методы, как показано ниже.

//Replicating data from local database to remote database 
localDB.replicate.to(remoteDB);

//Replicating data from remote database to local database 
localDB.replicate.from(remoteDB);

Где, localDB это объект базы данных, хранящийся локально в PouchDB и remoteDB это объект базы данных, который хранится в CouchDB.

пример

Допустим, есть база данных с названием local_database в PouchDB, и он содержит 3 документа: doc1, doc2 и doc3, содержимое которых показано ниже.

doc1 = {_id: '003', name: 'Ram', age: 26, Designation: 'Programmer'} 
doc2 = {_id: '004', name: 'Robert', age: 27, Designation: 'Programmer'} 
doc3 = {_id: '005', name: 'Rahim', age: 28, Designation: 'Programmer'}

И есть база данных с названием Remote_Database в CouchDB и содержит 2 документа doc1, doc2, содержимое которых показано ниже.

doc1 = {_id: '001', name: 'Geeta', age: 25, Designation: 'Programmer'} 
doc2 = {_id: '002', name: 'Zara Ali', age: 24, Designation: 'Manager'}

Ниже приведен пример синхронизации этих двух баз данных, одна из которых хранится в PouchDB, а другая - в CouchDB, с использованием replicate.to() и replicate.from() методы.

//Requiring the package
var PouchDB = require('PouchDB');

//Creating local database object
var localDB = new PouchDB('local_database');

//Creating remote database object
var remoteDB = new PouchDB('http://localhost:5984/remote_database');

//Synchronising both databases
localDB.replicate.to(remoteDB);
remoteDB.replicate.from(localDB);
console.log("Databases synchronized successfully");

Сохраните приведенный выше код в файл с именем Synchronising_databases.js. Откройте командную строку и выполните файл JavaScript, используяnode как показано ниже.

C:\PouchDB_Examples >node Synchronising_databases.js

Это синхронизирует две базы данных remoteDB и localDB и отображает сообщение на консоли, как показано ниже.

Databases synchronized successfully.

После синхронизации двух баз данных посетите http://127.0.0.1:5984/_utils/index.html и выберите remote_database. Вы можете заметить, что документы локальной базы данных (003, 004, 005) были скопированы в эту базу данных, как показано ниже.

Таким же образом, если вы извлекаете содержимое local_database хранится в PouchDB, вы можете увидеть, что здесь были скопированы документы базы данных, хранящейся в CouchDB.

[ 
   { 
      id: '001',
      key: '001',
      value: { rev: '1-23cf3767e32a682c247053b16caecedb' },
      doc: { 
         name: 'Geeta',
         age: 25,
         Designation: 'Programmer',
         _id: '001',
         _rev: '1-23cf3767e32a682c247053b16caecedb' 
      } 
   },
   { 
      id: '002',
      key: '002',
      value: { rev: '1-d5bcfafbd4d4fae92fd7fc4fdcaa3a79' },
      doc: { 
         name: 'Zara Ali',
         age: 24,
         Designation: 'Manager',
         _id: '002',
         _rev: '1-d5bcfafbd4d4fae92fd7fc4fdcaa3a79' 
      } 
   },
   { 
      id: '003',
      key: '003',
      value: { rev: '1-bf4619471ac346fdde46cfa8fbf3587f' },
      doc: { 
         name: 'Ram',
         age: 26,
         Designation: 'Programmer',
         _id: '003',
         _rev: '1-bf4619471ac346fdde46cfa8fbf3587f' 
      } 
   },
   { 
      id: '004',
      key: '004',
      value: { rev: '1-29b8f803958c994e3eb37912a45d869c' },
      doc: { 
         name: 'Robert',
         age: 27,
         Designation: 'Programmer',
         _id: '004',
         _rev: '1-29b8f803958c994e3eb37912a45d869c' 
      } 
   },
   { 
      id: '005',
      key: '005',
      value: { rev: '1-0eb89f71998ffa8430a640fdb081abd2' },
      doc: { 
         name: 'Rahim',
         age: 28,
         Designation: 'Programmer',
         _id: '005',
         _rev: '1-0eb89f71998ffa8430a640fdb081abd2' 
      } 
   } 
]

Вы можете переписать указанную выше программу, используя sync() метод, предоставляемый PouchDB вместо двух методов replicate.to() и replicate.from() как показано ниже.

//Requiring the package
var PouchDB = require('PouchDB');

//Creating local database object
var localDB = new PouchDB('local');

//Creating remote database object
var remoteDB = new PouchDB('http://localhost:5984/remote_database');

//Synchronising Remote and local databases
localDB.sync(remoteDB, function(err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log(response);
   }
});

При выполнении вышеуказанной программы он синхронизирует две базы данных, отображая следующее сообщение.

{ 
   push: { 
      ok: true,
      start_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time),
      docs_read: 6,
      docs_written: 6,
      doc_write_failures: 0,
      errors: [],
      last_seq: 10,
      status: 'complete',
      end_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time) 
   },
   pull: { 
      ok: true,
      start_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time),
      docs_read: 0,
      docs_written: 0,
      doc_write_failures: 0,
      errors: [],
      last_seq: 2,
      status: 'complete',
      end_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time) 
   } 
}