Pouchdb-replication

提供:Dev Guides
移動先:案内検索

PouchDB-レプリケーション

PouchDBの最も重要な機能の1つはレプリケーションです。 データベースのコピーを作成できます。 ローカルに保存されたPouchDBインスタンスまたはリモートに保存されたCouchDBインスタンスのいずれかを複製できます。

構文

以下は、PouchDBでデータベースを複製する構文です。 ここでは、*ソースデータベース*のコピーがターゲットです。 このメソッドには、ソースデータベースと宛先データベースの場所を文字列形式で直接渡すか、それらを表すオブジェクトを渡すことができます。

PouchDB.replicate(source, target, [options])

ソースとターゲットの両方は、PouchDBインスタンスまたはCouchDBインスタンスのいずれかです。

LocalDBをCouchDBに複製する

PouchDBに sample_database という名前のデータベースがあり、次のような内容を持つ3つのドキュメントdoc1、doc2、doc3が含まれているとします。

doc1 = {_id: '001', name: 'Ram', age: 23, Designation: 'Programmer'}
doc2 = {_id: '002', name: 'Robert', age: 24, Designation: 'Programmer'}
doc3 = {_id: '003', name: 'Rahim', age: 25, Designation: 'Programmer'}

以下は、CouchDBにローカルに保存されている sample_database という名前のデータベースのコピーを作成する例です。

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

var localdb = 'sample_database';

//Creating remote database object
var remotedb = 'http://localhost:5984/sample_database';

//Replicating a local database to Remote
PouchDB.replicate(localDB, remoteDB);
console.log ("Database replicated successfully");

上記のコードを Replication_example.js という名前のファイルに保存します。 以下に示すように、コマンドプロンプトを開き、 node を使用してJavaScriptファイルを実行します。

C:\PouchDB_Examples >node Replication_example.js

これにより、CouchDBインスタンスにsample_databaseという名前のデータベースのコピーが作成され、以下に示すようにコンソールにメッセージが表示されます。

Database replicated successfully

次のリンク http://127.0.0.1:5984/_utils/indexl をクリックすると、データベースがCouchDBインスタンスに複製されているかどうかを確認できます。

クリックすると、CouchDBのデータベースのリストが表示されます。 データベース sample_database のコピーがここで作成されることも確認できます。

サンプルデータベース

複製されたデータベースを選択すると、以下に示すようにその内容を表示できます。

複製されたデータベース

CouchDBからPouchDBへの複製

CouchDBに Remote_Database という名前のデータベースがあり、3つのドキュメント、doc1、doc2、およびdoc3が含まれており、以下に示す内容があるとします。

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

以下は、ローカルストレージのCouchDBに保存されている Remote_Database という名前のデータベースのコピーを作成する例です。

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

var localdb = 'sample_database';

var remotedb = 'http://localhost:5984/sample_database1';

//Replicating a local database to Remote
PouchDB.replicate(remotedb, localdb);
console.log("Database replicated successfully");

上記のコードを Replication_example2.js という名前のファイルに保存します。 以下に示すように、コマンドプロンプトを開き、 node を使用してJavaScriptファイルを実行します。

C:\PouchDB_Examples >node Replication_example2.js

これにより、PouchDBインスタンスに remote_database という名前のデータベースのコピーが作成され、以下に示すようにコンソールにメッセージが表示されます。

Database replicated successfully

次のコードを実行することで、データベースがPouchインスタンスに複製されているかどうかを確認できます。

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

//Creating the database object
var db = new PouchDB('remote_database');

//Retrieving all the documents in PouchDB
db.allDocs({include_docs: true, attachments: true}, function(err, docs) {
   if (err) {
      return console.log(err);
   } else {
      console.log(docs.rows);
   }
});

上記のコードの実行時にデータベースが複製される場合、以下に示すように複製されたデータベースの内容を取得します。

[
   {
      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-c4cce025dbd30d21e40882d41842d5a4' },
      doc: {
         name: 'Mary',
         age: 23,
         Designation: 'Admin',
         _id: '003',
         _rev: '1-c4cce025dbd30d21e40882d41842d5a4'
      }
   }
]