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에는 다음과 같은 내용이있는 doc1, doc2, doc3의 3 개의 문서가 포함되어 있습니다.
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)
}
}