使用kibana进行简单的CRUD和版本控制

使用:

##创建文档之前先创建索引
PUT /toov5
##查询索引
GET /toov5
##创建文档  /索引/类型/id
PUT /toov5/user/1
{
  "name":"Jack",
  "age":66,
  "sex":0
}

##删除索引
DELETE /toov5


GET /toov5/user/1

 

{ } 表示一行数据  toov5 表示数据库

 

版本控制:

1.为什么要进行版本控制

为了保证数据再多线程操作下的准确性

 

2.悲观锁和乐观锁(CAS无所机制)

悲观锁:假设会发生并发冲突,屏蔽一切可能违反数据准确性的操作

  

乐观锁:假设不会发生并发冲突,只在提交操作是检查是否违反数据完整性。

 联系version字段 就知道了!!!   乐观锁版本控制

 如果在修改时候传入的version是7 但是 查看当前版本是6 不一致!   修改时候 哪个线程执行的块 哪个就改了

 悲观锁需要等待 效率低一些

 

3.内部版本控制和外部版本控制

内部版本控制:_version自增长,修改数据后,_version会自动的加1     解决并发情况下的一致性问题

 

外部版本控制:为了保持_version与外部版本控制的数值一致

使用version_type=external检查数据当前的version值是否小于请求中的version值   

 

posted @ 2019-01-20 20:35  toov5  阅读(353)  评论(0编辑  收藏  举报