PouchDB相对远程数据库(使用CouchDB / Cloudant)

时间:2017-06-16 11:41:14

标签: database couchdb pouchdb cloudant

我正在创建一个CouchApp,并对远程数据库和创建PouchDB对象有疑问。

  • CouchApp可从htps://subdomain.website.com/
  • 获得
  • CouchDB实例位于htps://username.cloudant.com/database
  • 我在数据库中使用重写规则
  • 从subdomain.website.com到username.cloudant.com/database/_design/client/_rewrite
  • 有一个虚拟主机
  • 我不使用复制,只使用直接连接

我目前使用以下方法创建一个新的PouchDB对象:

  

var db = new PouchDB(' htps://username.cloudant.com/database');

但我宁愿将其实例化为:

  

var db = new PouchDB(' / database');

  

var db = new PouchDB('数据库');

我的猜测是PouchDB将其视为本地数据库而不是远程数据库。我的想法是否正确,我怎样才能得到我想要的结果?我想删除URL的主机名,因为我想保持一切可移植性并将其复制到其他服务器上。

3 个答案:

答案 0 :(得分:2)

由于您定义了vhost,因此可以使用以下解决方法mabye:

var url = new URL(window.location.href);
var host = url.host;

var db = new PouchDB(host+"/database");

答案 1 :(得分:0)

  

我目前使用以下方法创建一个新的PouchDB对象:

     

var db = new PouchDB(' htps://username.cloudant.com/database');

     

但我宁愿将其实例化为:

     

var db = new PouchDB('数据库');

嗯,这不是个人偏好的问题,您可能需要远程数据库,本地数据库或两者兼而有之。

基本上,作为开发人员,您可能需要远程数据库:

const remoteDB=new PouchDB('https://username.cloudant.com/database')

此外,您可能需要一个本地数据库:

const localDB=new PouchDB('localDatabase')

然后,您可能需要sync远程和本地数据库。实际上,syncing PouchDB真正发光的。例如,同步可以这样做:

localDB.sync(remoteDB,{live:true,retry:true}).on('complete',()=>{
    console.log('sync done')
}).on('change',change=>{
    console.log('Something changed -> ',change)
}).on('paused',info=>{
    console.log('Sync paused -> ',info)
}).on('active',info=>{
    console.log('Sync is active again -> ',info)
}).on('error',err=>{
    throw new Error(err)
})

您可以read on了解更多信息。

答案 2 :(得分:0)

我能够弄清楚)

我正在使用create-react-app,并希望使用proxy指令,因此我可以将所有pouchdb请求重定向到我的/couchdb1端点,并避免所有CORS问题。

所以你去了:

const COUCHDB_ROOT = '/couchdb1';
const remoteDB = new PouchDB(COUCHDB_ROOT + '/userdb-626f62', {
  adapter: 'http',
  fetch: (url, opts) => {
    if (typeof url === 'string') {
      return PouchDB.fetch(COUCHDB_ROOT + url.split(COUCHDB_ROOT)[1], opts)
    } else {
      throw new Error('The url could be of a Request type.'); // TODO
    }
  },
  auth: {
    username: 'bob',
    password: 'bob',
  },
  skip_setup: true,
});