Elasticsearch索引和文檔操作

来源:http://www.cnblogs.com/ginb/archive/2017/06/12/6993299.html
-Advertisement-
Play Games

列出所有索引 現在來看看我們的索引 返回內容如下: 可以看到在集群中有一個索引 創建索引 現在讓我們創建一個名叫 customer 的索引,然後再次列出所有的索引 執行第一行返回以下內容,這裡我們使用PUT謂詞創建了一個名叫 customer 的索引,在後面跟上 pretty 表示如果有數據返回的話 ...


列出所有索引

現在來看看我們的索引

GET /_cat/indices?v

返回內容如下:

health status index   uuid                   pri rep docs.count docs.deleted store.size pri.store.size
yellow open   .kibana XYZPR5XGQGWj8YlyZ1et_w   1   1          1            0      3.1kb          3.1kb

可以看到在集群中有一個索引

創建索引

現在讓我們創建一個名叫 customer 的索引,然後再次列出所有的索引

PUT /customer?pretty
GET /_cat/indices?v

執行第一行返回以下內容,這裡我們使用PUT謂詞創建了一個名叫 customer 的索引,在後面跟上 pretty 表示如果有數據返回的話,用格式化後的JSON返回數據

{
  "acknowledged": true,
  "shards_acknowledged": true
}

執行第二行返回以下內容,結果告訴我們,已經創建了一個名叫 customer  的索引,它有5個主分片和1個複製分片(預設情況下是1個),在這個索引中還沒有文檔。

health status index    uuid                   pri rep docs.count docs.deleted store.size pri.store.size
yellow open   .kibana  XYZPR5XGQGWj8YlyZ1et_w   1   1          1            0      3.1kb          3.1kb
yellow open   customer M8i1ZxhsQJqk7HomOA7c_Q   5   1          0            0       650b           650b

可能你已經註意到 customer 索引的健康值被標記為 yellow ,回顧我們前面討論的內容, yellow 表示該索引的複製分片(副本)還沒有被分配。該索引出現這種情況的原因是, Elasticsearch 預設會為該索引創建1個副本,由於此時我們只有1個節點,那麼這副本就沒法被分配(為了高可用),直到以後為該集群加入了另一個節點。一旦該副本分配到了另一個節點,該索引的健康狀態就會變成 green 。

索引和查詢文檔

接下來我們放一些東西到 customer  索引中。之前提過的,為了索引某個文檔,我們必須告訴 Elasticsearch  ,該文檔應該屬於該索引的哪個類型,下麵我們索引一個簡單的文檔到 customer  索引,類型名稱為 external ,  並且ID為1

PUT /customer/external/1?pretty
{
  "name": "John Doe"
}

返回內容如下:

{
  "_index": "customer",
  "_type": "external",
  "_id": "1",
  "_version": 1,
  "result": "created",
  "_shards": {
    "total": 2,
    "successful": 1,
    "failed": 0
  },
  "created": true
}

從以上可以看出,一個新的客戶文檔成功被索引到 customer索引的 extenal 類型中,並且我們在索引的時候指定文檔的內部id值為1。

值得註意的是, Elasticsearch 不需要在你索引文檔到某個索引之前,明確的創建一個索引。比如上一個例子,如果 customer索引不存在, Elasticsearch將自動創建該索引。

再來看下我們剛剛索引的文檔

GET /customer/external/1?pretty

返回內容如下:

{
  "_index": "customer",
  "_type": "external",
  "_id": "1",
  "_version": 1,
  "found": true,
  "_source": {
    "name": "John Doe"
  }
}

這裡比較特殊的是found欄位,它說明我們查到了一個id為1的文檔,另一特殊的欄位_source,保存了在上一個步驟索引的的文檔。

刪除索引

現在讓我們刪除剛剛已經創建的索引,並再次查看所有索引。

DELETE /customer?pretty
GET /_cat/indices?v

第一行返回內容以下:

{
  "acknowledged": true
}

第二行返回內容如下:

health status index   uuid                   pri rep docs.count docs.deleted store.size pri.store.size
yellow open   .kibana XYZPR5XGQGWj8YlyZ1et_w   1   1          1            0      3.1kb          3.1kb

從以上內容可以看到我們的 customer索引已經被刪除了。

在繼續學習之前,讓我們快速回顧一下,本節學的API命令

PUT /customer
PUT /customer/external/1
{
  "name": "John Doe"
}
GET /customer/external/1
DELETE /customer

如果仔細學習了以上命令,應該會發現 elasticsearch 訪問數據所使用的模式,概括如下:

<REST Verb> /<Index>/<Type>/<ID>

使用REST 訪問模式,在所有的API命令中是十分普遍的,如果你可以簡單記住它,對於掌握 Elasticsearch ,那麼已經開了一個好頭。

修改數據

 Elasticsearch  具有近實時的操作和查詢數據的能力,預設情況下,從你索引,更新或者刪除你的數據到用戶可以搜索到新的結果這個過程大概需要1秒(基於refresh 頻率)。它們和類似SQL這樣的平臺不一樣,SQL的數據在事務完成後就馬上就生效,不會有延遲。

索引/替換文檔

之前已經演示了怎麼索引單個文檔,再來回顧一下:

PUT /customer/external/1?pretty
{
  "name": "John Doe"
}

上面的命令將會索引指定文檔到 customer 索引的 external 類型,文檔的id值是1。如果我們用不同的文檔內容(或者相同)再次執行上面的命令,elasticsearch將會用一個新的文檔取代舊的文檔(即重建索引)。

PUT /customer/external/1?pretty
{
  "name": "Jane Doe"
}

上面的操作把id為1的文檔的name欄位由"john doe"改成"jane doe"。另一方面,如果我們使用不同的id執行上述命令,將會創建一個新的文檔,舊的文檔會保持原樣。

PUT /customer/external/2?pretty
{
  "name": "Jane Doe"
}

以上操作索引了一個新的id為2文檔。

索引新文檔的時候,id值是可選的。如果沒有指定, elasticsearch 將會為文檔生成一個隨機的id。實際生成的id將會保存在調用api介面的返回結果中。

下麵的例子展示不指定文檔id的時候是如何索引文檔的:

POST /customer/external?pretty
{
  "name": "Jane Doe"
}

返回內容如下:

{
  "_index": "customer",
  "_type": "external",
  "_id": "AVyc9L6dtgHksqXKpTlM",
  "_version": 1,
  "result": "created",
  "_shards": {
    "total": 2,
    "successful": 1,
    "failed": 0
  },
  "created": true
}

註意,在上面的例子中,因為沒有指定id,我們需要使用POST謂詞取代之前的PUT謂詞。

更新文檔

除了可以索引和替換文檔之外,我們還可以更新文檔。註意, elasticsearch 並沒有在原來的文檔基礎上進行更新,每當進行更新時, Elasticsearch 將刪除舊的文檔,然後索引新的文檔。以下例子演示瞭如何更新文檔,把之前ID為1的name欄位改為"Jane Doe":

POST /customer/external/1/_update?pretty
{
  "doc": { "name": "Jane Doe" }
}

以下例子演示瞭如何更新先前ID為1的文檔,改變name欄位為"Jane Doe" 的同時添加age欄位

POST /customer/external/1/_update?pretty
{
  "doc": { "name": "Jane Doe", "age": 20 }
}

也可以使用簡單的腳本來執行更新。以下示例使用腳本將年齡增加5:

POST /customer/external/1/_update?pretty
{
  "script" : "ctx._source.age += 5"
}

在以上例子中, ctx._source 指當前即將被更新的源文檔。請註意,在撰寫本文時,只能一次更新單個文檔。將來, Elasticsearch 可能會提供通過查詢條件(如SQL UPDATE-WHERE語句)更新多個文檔的功能。

刪除文檔

刪除文檔非常簡單,以下例子演示了怎麼刪除 customer 索引下ID為2的文檔,查閱Delete By Query API 刪除與特定查詢匹配的所有文檔。值得註意的是,直接刪除整個索引比通過query api 刪除所有文檔更高效。

DELETE /customer/external/2?pretty

批處理

除了能夠索引,更新和刪除單個文檔之外, Elasticsearch  也提供了使用  _bulk API 批量執行上述任何操作的功能這個功能是非常重要的,因為它提供了一個非常有效的機制來儘可能快地進行多個操作,並且儘可能減少網路的往返行程。簡單舉個例子,下麵會在一個 bulk操作中索引兩個文檔:

POST /customer/external/_bulk?pretty
{"index":{"_id":"1"}}
{"name": "John Doe" }
{"index":{"_id":"2"}}
{"name": "Jane Doe" }

返回內容如下:

{
  "took": 27,
  "errors": false,
  "items": [
    {
      "index": {
        "_index": "customer",
        "_type": "external",
        "_id": "1",
        "_version": 1,
        "result": "created",
        "_shards": {
          "total": 2,
          "successful": 1,
          "failed": 0
        },
        "created": true,
        "status": 201
      }
    },
    {
      "index": {
        "_index": "customer",
        "_type": "external",
        "_id": "2",
        "_version": 1,
        "result": "created",
        "_shards": {
          "total": 2,
          "successful": 1,
          "failed": 0
        },
        "created": true,
        "status": 201
      }
    }
  ]
}

下麵的例子會在一個操作內更新第一個文檔同時刪除第二個文檔:

POST /customer/external/_bulk?pretty
{"update":{"_id":"1"}}
{"doc": { "name": "John Doe becomes Jane Doe" } }
{"delete":{"_id":"2"}}

返回內容如下:

{
  "took": 25,
  "errors": false,
  "items": [
    {
      "update": {
        "_index": "customer",
        "_type": "external",
        "_id": "1",
        "_version": 2,
        "result": "updated",
        "_shards": {
          "total": 2,
          "successful": 1,
          "failed": 0
        },
        "status": 200
      }
    },
    {
      "delete": {
        "found": true,
        "_index": "customer",
        "_type": "external",
        "_id": "2",
        "_version": 2,
        "result": "deleted",
        "_shards": {
          "total": 2,
          "successful": 1,
          "failed": 0
        },
        "status": 200
      }
    }
  ]
}

註意以上的刪除操作,在它之後並沒有相應的源文檔,因為只需要文檔的ID就能刪除。

如果某個操作因某些原因執行失敗,不會影響後面的操作,它會繼續執行剩下的操作。api返回結果時,每一個操作都會提供狀態(和接收到的順序一致),你可以通過這個狀態檢查操作是否執行成功。

官方文檔

https://www.elastic.co/guide/en/elasticsearch/reference/current/_exploring_your_cluster.html

https://www.elastic.co/guide/en/elasticsearch/reference/current/_modifying_your_data.html

參考文檔

https://github.com/13428282016/elasticsearch-CN/wiki/es-gettting-started


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在Ubuntu系統上安裝vim是遇到的問題: 出現這個問題可能是有另外一個程式正在運行,導致資源被鎖不可用。而導致資源被鎖的原因可能是上次運行安裝或更新時沒有正常完成,進而出現此狀況,解決的辦法其實很簡單: 在終端輸入以下兩句命令: 執行之後即可再次安裝vim文本編輯器了。 ...
  • 預設登錄的是普通用戶許可權顯示$符 從普通用戶切換超級用戶許可權: sudo su 輸入密碼 輸入密碼之後即可切換到超級用戶了。 從超級用戶切換普通用戶:su 用戶名 從超級用戶切換到普通用戶是不需要輸入密碼的,輸入上面的命令之後直接回車即可 這樣就有切換回普通用戶了。 ...
  • 1、檢查一下系統中的jdk版本 顯示: 2、檢測jdk安裝包 顯示: 3、卸載openjdk 之後再次輸入rpm -qa | grep java 查看卸載情況: 4、安裝新的jdk 首先到jdk官網上下載你想要的jdk版本,下載完成之後將需要安裝的jdk安裝包放到Linux系統指定的文件夾下,並且命 ...
  • ———————————————————————————————————————————— D/A轉換器 CS=0、ILE=1時,WR1信號有效時將數據匯流排上的信號寫入8位輸入鎖存器 XFER=0時,WR2信號有效時將輸入寄存器的數據轉移到8位DAC寄存器中,輸出量隨之改變 工作方式: 直通工作方式( ...
  • 軟體raid 5的實現 RAID 5 是一種存儲性能、數據安全和存儲成本兼顧的存儲解決方案。 RAID 5可以理解為是RAID 0和RAID 1的折中方案。RAID 5可以為系統提供數據安全保障,但保障程度要比Mirror低而磁碟空間利用率要比Mirror高。RAID 5具有和RAID 0相近似的數 ...
  • 軟體RAID 0的實現 RAID 0又稱為Stripe或Striping,它代表了所有RAID級別中最高的存儲性能。RAID 0提高存儲性能的原理是把連續的數據分散到多個磁碟上存取,這樣,系統有數據請求就可以被多個磁碟並行的執行,每個磁碟執行屬於它自己的那部分數據請求。這種數據上的並行操作可以充分利 ...
  • 自定義生成事件打開方式 通過指定自定義生成事件,可以在生成開始之前或在它完成之後自動運行命令。在Visual Studio中通過右鍵項目 》屬性 進入項目屬性菜單。 自定義生成事件的語法 生成事件遵循與 DOS 命令相同的語法。如 在啟動調試時在某個目錄下創建文件夾 通過內置的巨集列表可以更快速的輸入 ...
  • 作者:Parry 出處:http://www.cnblogs.com/parry/ 本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。 這是一篇新手入門的一篇非常不錯的文章,強烈推薦!聯繫我加微信:jkxx123321 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...