couchbase php,从PHP SDK设置后,Couchbase视图不会更新

在PHP应用中使用Couchbase数据库时,开发者遇到一个问题,即存储文档后立即通过视图检查新文档不总是返回最新结果。尽管设置了'stale' => false以确保数据是最新的,但新文档并不总是显示。尝试了keyDurability和不同的选项配置,问题依然存在。解决方案是使用keyDurability方法配合持久化设置,确保文档写入磁盘后再触发视图更新,从而获取最新数据。
摘要由CSDN通过智能技术生成

我正在开发一个应用程序,我主要使用视图来获取数据.

我尝试做的是,存储文档,重定向并检查存储的文档是否可用(这是通过视图完成的,因为我不是在查找文档密钥,而是查找不同的值).

我在用什么?

Debian Wheezy上的PHP(5.4.21),Couchbase(2.1.1)和Couchbase的PHP SDK(1.1).

那么发生了什么?

我存储了一个包含API函数集($id,$document)的文档,然后使用API​​函数视图($designDocument,$viewName,$options)触发视图更新,其中$options至少包含’stale’ => false,然后重定向到另一个页面,我检查新添加的文档/或只是想显示它.

但新添加的文档并不总是显示或不总是通过我的检查存在.

按照我正在使用的代码更详细:

public function store(AbstractDocument $document)

{

$result = $this->bucket->storeDocument($document->getId(),

json_encode($document));

$this->afterSave();

return $result;

}

public function storeDocument($id, $document)

{

if (!is_string($document)) {

$document = json_encode($document);

}

$res = $this->couchbase->set($id, $document);

return $res;

}

public function afterSave()

{

$this->bucket->triggerViewIndexing(

$this->getDesignDocumentName(),

Config::KEY_COUCHBASE_VIEW_USER_USERLIST

);

}

public function triggerViewIndexing($designDocument, $viewName)

{

$options = ['limit' => 1, 'stale' => false];

$res = $this->couchbase->view($designDocument, $viewName, $options);

}

如代码所示,我将stale参数设置为false,以确保更新索引.

但它似乎没有奏效.

在写这个问题之前,我查看了Couchbase论坛中的一些主题,Stackoverflow上的帖子,Couchbase的PHP SDK文档以及Couchbase的一般文档.

所以我想我理解stale应该如何工作以及limitations似乎是什么.

如果我的假设陈旧有效,但只有当文件不再在内存中而是被写入磁盘(或已经有)时,是错误的,请随时纠正我.

正如我想要做的那样是不行的,我尝试了不同的东西,在一些解释和文件中也提到了应该有助于实现我想要的结果.

例如,我认为如果stale的默认行为是update_after,然后触发索引的两次更新,将解决问题.

好吧,它没有.

其他值得注意的事情是

$this->couchbase->keyDurability($id,$res);

$this->couchbase->observe($id, $res);

我将文件与套装一起存放后直接使用,单独和绝望组合使用.

也没有做到这一点.

我的假设是错误的是,PHP SDK或者某种程度上不通过stale = false参数而keyDurability没有做到它应该做的事情.当我在检查新创建的文档时传递stale = false,当然两个(触发器和检查)都在同一个存储桶和视图上工作.

或者我在做一些可怕的错误而没有注意到它.

如果有人能指出我正确的方向并希望解释出了什么问题,我会很高兴,因为我无法理解正在发生的事情.根据我的理解,everthing应该至少与keyDurability和stale一起使用.

解决方法:

有关更新视图的“问题”是,它仅使用持久保存到磁盘的数据.

你可以使用keyDurability()来检查是否发生了这种情况,但是你需要你刚才写的元素的id和cas.

我会将你的triggerViewIndexing函数更改为这样.

/**

* @param $designDocument

* @param $viewName

* @param null $id

* @param null $cas

*/

public function triggerViewIndexing($designDocument, $viewName, $id = null, $cas = null)

{

if (!empty($id) && !empty($cas)) {

$details = [

'persist_to' => 1, //The number of nodes the document should be persisted to

'timeout' => 2000, // The max time to wait for durability

'interval' => 100 //The interval between checking the state of the document

];

$this->couchbase->keyDurability($id, $cas, $details);

}

$options = ['limit' => 1, 'stale' => false];

$res = $this->couchbase->view($designDocument, $viewName, $options);

}

如果将项目写入磁盘,则每100ms检查最多2000ms.

之后,触发视图将刷新数据.

标签:php,couchbase,couchbase-view

来源: https://codeday.me/bug/20190703/1367103.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值