IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> elasticSearch核心概念的介绍(十八):ES的乐观锁 -> 正文阅读

[大数据]elasticSearch核心概念的介绍(十八):ES的乐观锁

锁的简单分类

  • 悲观锁

顾名思义,就算很悲观,每次去拿数据的时候都认为别人会修改,所以在每次拿到数据的时候都会上锁,这样别人想拿到这个数据就会阻塞,直到它拿到锁。传统的关系型数据库里面就用到了很多这种锁机制,比如行锁、表锁、读锁、写锁等,都是在做操作之前先上锁。

  • 乐观锁

顾名思义,就算很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,比如可以使用版本号等机制。乐观锁适用于多读的应用类型,这样可以提高吞吐量,因为我们elasticsearch一般业务场景都是写少读多,所以通过乐观锁可以在控制并发的情况下又能有效的提高系统吞吐量。

  • 版本号乐观锁

1、elasticsearch中对文档的index,GET和DELETE请求时候,都会返回一个_version,当文档被修改时版本号递增
2、所有文档的更新或删除API,都可以介绍version参数,这允许你在代码中使用乐观的并发控制,这里要注意的时版本号要大于旧的版本号,并且加上version_type=external


获取文档

curl -X GET "http://47.93.35.38:9200/nba/_doc/1"

返回结果

{
    "_index": "nba",
    "_type": "_doc",
    "_id": "1",
    "_version": 1,
    "_seq_no": 0,
    "_primary_term": 1,
    "found": true,
    "_source": {
        "name": "张三",
        "team_name": "火箭",
        "position": "前锋",
        "play_year": "10",
        "jerso_no": "13"
    }
}

可以看到当前的_version等于1

我们通过版本号去修改数据

curl -X PUT "http://47.93.35.38:9200/nba/_doc/1?version=1&version_type=external" -H 'Content-Type:application/json' -d '
{
    "name":"张三1",
    "team_name":"火箭",
    "position":"前锋",
    "play_year":"10",
    "jerso_no":"13"
}
'

返回结果

{
    "error": {
        "root_cause": [
            {
                "type": "version_conflict_engine_exception",
                "reason": "[1]: version conflict, current version [1] is higher or equal to the one provided [1]",
                "index_uuid": "m_z801WySBCVX-ujrGSv8g",
                "shard": "2",
                "index": "nba"
            }
        ],
        "type": "version_conflict_engine_exception",
        "reason": "[1]: version conflict, current version [1] is higher or equal to the one provided [1]",
        "index_uuid": "m_z801WySBCVX-ujrGSv8g",
        "shard": "2",
        "index": "nba"
    },
    "status": 409
}

可以看到报错了,因为我们在进行修改等操作时,版本号要大于当前版本号才行

修改版本号在进行修改

curl -X PUT "http://47.93.35.38:9200/nba/_doc/1?version=2&version_type=external" -H 'Content-Type:application/json' -d '
{
    "name":"张三1",
    "team_name":"火箭",
    "position":"前锋",
    "play_year":"10",
    "jerso_no":"13"
}
'

返回结果

{
    "_index": "nba",
    "_type": "_doc",
    "_id": "1",
    "_version": 2,
    "result": "updated",
    "_shards": {
        "total": 3,
        "successful": 3,
        "failed": 0
    },
    "_seq_no": 1,
    "_primary_term": 1
}

修改成功,并且返回了当前文档的版本号

再次查看数据

curl -X GET "http://47.93.35.38:9200/nba/_doc/1"

返回结果

{
    "_index": "nba",
    "_type": "_doc",
    "_id": "1",
    "_version": 2,
    "_seq_no": 1,
    "_primary_term": 1,
    "found": true,
    "_source": {
        "name": "张三1",
        "team_name": "火箭",
        "position": "前锋",
        "play_year": "10",
        "jerso_no": "13"
    }
}

数据也被正常修改

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-06 13:08:12  更:2022-03-06 13:12:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 19:54:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码