十九、Elasticsearch如何基于_version进行乐观
2017-07-05 本文已影响108人
编程界的小学生
1、_version元数据
PUT /test_index/test_type/6
{
"test_field" : "test test"
}
返回结果
{
"_index": "test_index",
"_type": "test_type",
"_id": "6",
"_version": 1,
"result": "created",
"_shards": {
"total": 5,
"successful": 1,
"failed": 0
},
"created": true
}
第一次创建一个document的时候,他的_version内部版本号就是1;以后,每次对这个document执行修改或者删除操作,都会对这个_version版本号自动加1;哪怕是删除也会对这条数据的版本号加1。
DELETE /test_index/test_type/6
返回结果
{
"found": true,
"_index": "test_index",
"_type": "test_type",
"_id": "6",
"_version": 2,
"result": "deleted",
"_shards": {
"total": 5,
"successful": 1,
"failed": 0
}
}
再次PUT
PUT /test_index/test_type/6
{
"test_field" : "test test"
}
返回结果:
{
"_index": "test_index",
"_type": "test_type",
"_id": "1",
"_version": 3,
"result": "updated",
"_shards": {
"total": 5,
"successful": 1,
"failed": 0
},
"created": false
}
发现版本号变成了3
我们发现,再删除一个document之后,可以从一个侧面证明,他不是立即物理删除的,因为他的一些版本号等信息还是保留着的。先删除一条document,再重新创建这条document,其实会在delete version基础之上,再把version号加1

若有兴趣,欢迎来加入群,【Java初学者学习交流群】:458430385,此群有Java开发人员、UI设计人员和前端工程师。有问必答,共同探讨学习,一起进步!
欢迎关注我的微信公众号【Java码农社区】,会定时推送各种干货:
