Delete API
delete API允许基于指定的ID来从索引库中删除一个JSON文件。下面演示了从一个叫twitter
的索引库的tweet
type下删除文档,id
是1
:
上述删除操作的结果是:
版本
索引的每个文档都被标记了版本。当删除文档时, 可以通过指定version
来确保我们试图删除一个实际上已被删除的文档时,它在此期间并没有改变。在文档中执行的每个写入操作,包括删除,都会使其版本递增。
路由
在创建索引文档时如果使用了控制路由的能力,为了删除文档,也应当提供路由值。例如:
以上将删除ID为1的tweet,但会根据用户路由。请注意,如果删除路由值不正确,会导致文档无法删除。
当映射的_routing
被设定为required
且没有指定的路由值时,删除API将抛出RoutingMissingException
并拒绝该请求。
Parent
parent
参数可以被设置,这将基本上与设定路由参数是相同的。
当删除子文档,必须指定其父ID,否则该删除请求将被拒绝和抛出一个RoutingMissingException
异常。
自动创建索引
分布式
删除操作被散列到一个特定的分片id。然后它被重定向到该ID组内的主分片,和副本分片(如果需要的话)。
等待活动分片
刷新
超时
在执行删除操作时,分配给执行删除操作的主分片可能无法使用。有些方面的原因可能是主分片正在从仓库恢复或进行搬迁。默认情况下,删除操作在返回失败与错误之前将等待1分钟让主分片成为可用的。该timeout
参数可用于明确指定等待多长时间。这里是将其设置为5分钟的一个示例:
Last updated
Was this helpful?