ElasticSearch6.3.2 集群做節點冷(warm) 熱(hot) 分離

来源:https://www.cnblogs.com/hapjin/archive/2019/08/10/11314492.html
-Advertisement-
Play Games

拿一個小規模的5節點ES集群做冷熱分離嘗試,它上面已經有60多個索引,有些索引按月、每月生成一個索引,隨著數據的不斷寫入,歷史數據(只需保留三個月數據,三個月之前的數據視為歷史數據)越來越占磁碟空間和記憶體資源,影響搜索響應時間。因此想把集群中節點分成2種類型,一種是hot節點,配置大記憶體和SSD,用 ...


拿一個小規模的5節點ES集群做冷熱分離嘗試,它上面已經有60多個索引,有些索引按月、每月生成一個索引,隨著數據的不斷寫入,歷史數據(只需保留三個月數據,三個月之前的數據視為歷史數據)越來越占磁碟空間和記憶體資源,影響搜索響應時間。因此想把集群中節點分成2種類型,一種是hot節點,配置大記憶體和SSD,用來扛平常的用戶請求;一種是warm節點,機械硬碟小記憶體,用來存儲歷史不常用的數據,和偶爾的後臺任務查詢。

把現有的5台節點全做hot節點,另外新增2台節點做warm節點。參考官方bloghot-warm-architecture-in-elasticsearch-5-x架構實現。需要註意的地方主要是:不要讓已有的索引分片被ES自動Rebalance到warm節點上去了,並且新創建的索引,只應該分配在hot節點上。下麵來看具體的實現步驟:

第一步:禁用 rebalance

主要是為了防止集群中已有的索引 rebalance 到 新添加的2台warm節點上去,我們只想手動把那些歷史索引 遷移到warm節點上。

PUT _cluster/settings
{
  "transient": {
    "cluster.routing.allocation.cluster_concurrent_rebalance":0
  }
}

第二步:給節點加標識:node.attr.box_type

關於 node.attr.box_type 屬性介紹,可參考:enabling-awareness

修改hot節點的elasticsearch.yml配置文件,添加一行:

node.attr.box_type: hot

修改warm節點的elasticsearch.yml配置文件,添加一行:

node.attr.box_type: warm

第三步:定義通用的索引模板保證新創建索引的分片不會分配到warm節點上

當每月生成一個索引時,新建的索引,肯定是熱索引,熱索引的分片需要分配到hot節點上,不能分配到warm節點上。比如,loginmac-201908是新建的索引,其分配應該在hot節點上,假設只保留三個月的數據,那麼 loginmac-201905就屬於歷史數據了,需要遷移到warm節點上去。

PUT /_template/hot_template
{
  "template": "*",
  "order": 0,
  "version": 0,
  "settings": {
    "index": {
      "routing": {
        "allocation": {
          "require": {
            "box_type": "hot"
          },
          "exclude":{
            "box_type": "warm"
          }
        }
      },
      "number_of_shards": 3,
      "number_of_replicas": 1,
      "refresh_interval": "50s"
    },
    "index.unassigned.node_left.delayed_timeout": "3d"
  }
}

關於index.routing.allocation.requireindex.routing.allocation.exclude可參考:shard-allocation-filtering

第四步 把系統上已有索引的配置全部修改成hot配置

PUT _all/_settings
{
  "index": {
    "routing": {
      "allocation": {
        "require": {
          "box_type": "hot"
        }
      }
    }
  }
}

這是為了,保證當warm節點加入集群時,不要讓熱索引遷移到到warm節點上。

第五步 重啟所有的修改了elasticsearch.yml 配置為 hot 的節點。等待所有的索引初始化完畢

第六步 啟動將 elasticsearch.yml 配置為 warm 的節點,並把歷史索引數據配置信息修改成 warm

比如 將loginmac-201905索引的配置 改成 box_type 屬性改成 warm。(box_type就是用來標識節點屬性的)

PUT loginmac-201905/_settings
{
  "index": {
    "routing": {
      "allocation": {
        "require": {
          "box_type": "warm"
        }
      }
    }
  }
}

第七步 執行reroute命令,將 box_type為warm的索引遷移到 warm節點上。

其中,node-248是hot節點,node-12是warm節點。

POST /_cluster/reroute
{
  "commands": [
    {
      "move": {
        "index": "loginmac-201905",
        "shard": 2,
        "from_node": "node-248",
        "to_node": "node-12"
      }
    }
  ]
}

最後,來一張集群冷熱節點的示意圖:

調整後碰到的一些問題:

在修改 node-02 節點的ES 配置文件時:node.attr.box_type: hot重啟後節點並未生效,導致這台節點上的分片全部被遷移到其他節點上去了。

GET /_nodes/node-02

重啟node-02(在Ubuntu16上,先用 su user_00 切換到user_00用戶,然後再執行 ./bin/elasticsearch -d 啟動ES進程,我用 sudo -u user_00 ./bin/elasticsearch -d 啟動ES時老是報 memory not lock 錯誤)

再查看節點信息,可看到節點帶有 box_type 為 hot 的屬性了。

      "attributes": {
        "box_type": "hot",
        "xpack.installed": "true"
      }

所以,在修改了elasticsearch.yml配置文件並重啟節點後,最好先GET /_nodes/node-02看一下配置是否生效,否則可能造成大量分片reroute,浪費資源。

做完冷熱分離後,還可以再做一些其他的優化:

  1. 段合併

    查看索引loginmac-201905各個段的情況,並force merge

    GET /_cat/segments/loginmac-201905?v&h=shard,segment,size,size.memory

    POST /loginmac-201905/_forcemerge?max_num_segments=10&flush=true

  2. 關閉索引

    POST /loginmac-201905/_close

原文:https://www.cnblogs.com/hapjin/p/11314492.html


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

-Advertisement-
Play Games
更多相關文章
  • 在不用代碼調從而啟動某個軟體時,windows系統下,通常我們會用到cmd命令行來啟動。本文將介紹 cmd常見的命令行啟動參數。 ...
  • 本篇文章包含了curl的常用案例使用。 如果想瞭解curl選項的詳細說明,請參考前一篇文章「Linux curl 命令詳解」。 常見網頁訪問示例 基本用法 訪問一個網頁 執行後,相關的網頁信息會列印出來 進度條展示 有時候我們不需要進度表展示,而需要進度條展示。比如:下載文件時。 可以通過 -#, ...
  • Matomo(Piwik)安裝說明 安裝前環境檢查 開始安裝PHP7.2(yum安裝,如果已安裝則忽略此步驟) Tips:安裝前請檢查Linux是否內置了PHP5.4及以下版本,否則安裝會出錯 linux的yum源不存在php7.x,所以要更改yum源 # rpm -Uvh https://dl.f ...
  • 1.搭建zookeeper docker pull wurstmeister/zookeeperdocker run -d --name zookeeper -p 2181:2181 --volume /etc/localtime:/etc/localtime -t wurstmeister/zoo ...
  • 一、查看磁碟分區使用狀況 df [選項] 其中,-l是預設選項 -a 會顯示出包括0位元組分區在內的所有文件系統分區 -t 後須跟一個參數,這個參數為文件系統的名字,用來在系統中查找屬於該文件系統的分區 -x 後也須文件系統名作為參數,需要註意的是,若和其他參數混合使用,x需要出現在最後,例如 二、統 ...
  • --方法1.PLSQL代碼塊 SQL> set serveroutput onSQL> declare 2 v_sal emp_pl.sal%type; 3 begin 4 v_sal :=get_sal(7902); 5 dbms_output.put_line('7902的工資是'||v_sal ...
  • PostgreSQL是一個功能強大的開源對象關係資料庫管理系統(ORDBMS),在開源資料庫使用上與MySQL各領風騷。但也有不少人質疑postgresql的未來,正所謂,贊揚或批判一種資料庫都必須先瞭解它,然後才可有話語權。為了更多的瞭解postgresql,我們就先部署一套實例作為瞭解它的基礎。 ...
  • 0 學習路線的知識點概括 學習電腦組成原理,就是學習電腦是如何協調運行的 電腦組成原理的英文叫Computer Organization Organization 意"組織機構"。 該組織機構能夠進行各種計算、控制、讀取輸入,進行輸出,達成各種強大的功能。 把整個電腦組成原理的知識點拆分成了 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...