Docker下elasticsearch8部署、擴容、基本操作實戰(含kibana)

来源:https://www.cnblogs.com/bolingcavalry/archive/2023/08/21/17642368.html
-Advertisement-
Play Games

本文通過docker快速部署elasticsearch8版本,再添加一臺組成集群,並且部署kibana用於常規查詢操作,以及一些常見的es操作 ...


歡迎訪問我的GitHub

這裡分類和彙總了欣宸的全部原創(含配套源碼):https://github.com/zq2599/blog_demos

本篇概覽

  • 本篇記錄了用docker搭建ElasticSearch8單機版再擴容的過程,既留給自己後面反覆使用,也可以為正在部署環境的讀者提供一些參考
  • 請註意docker部署ElasticSearch的適用場景:我這邊只是在開發過程中使用,這種方式在生產環境是否適合是有待商榷的,在用於生產環境時請慎重考慮
  • 本篇由以下內容構成
  1. 介紹本次實戰的環境和版本信息
  2. 快速部署
  3. 驗證功能
  4. 新加節點
  5. 一些常用操作介紹

環境信息

  • 以下是本次實戰的環境信息,可以作為參考
  1. 操作系統:macOS Monterey(M1 Pro晶元的MacBook Pro,16G記憶體)
  2. Docker:Docker Desktop 4.7.1 (77678)
  3. ElasticSearch:8.2.2
  4. Kibana:8.2.2

準備工作

  • 首先是docker鏡像加速,沒有加速手段的下載鏡像體驗會很差,我這邊里用的是七牛的鏡像加速(https://reg-mirror.qiniu.com),您可以按個人喜好自行配
  • 如果您的環境是Linux,註意要做以下操作,否則es可能會啟動失敗
    1 用編輯工具打開文件/etc/sysctl.conf
    2 在尾部添加一行配置vm.max_map_count = 262144,如果已存在就修改,數值不能低於262144
    3 修改保存,然後執行命令sudo sysctl -p使其立即生效

部署es

  • 先創建一個docker網路
docker network create elastic
  • 創建es容器,若本地沒有鏡像會自動下載,為了省記憶體,我這裡設置ES容器內的java進程只用到1024M記憶體,您可以根據自己電腦情況調整
docker run \
--name es01 \
--net elastic \
-p 9200:9200 \
-e ES_JAVA_OPTS="-Xms1024m -Xmx1024m" \
-idt elasticsearch:8.2.2
  • 進入容器
docker exec -it es01 /bin/bash
  • 重置密碼
bin/elasticsearch-reset-password -u elastic
  • 提示是否重置,輸入y,控制台會列印新密碼,請記住這個密碼,稍後要用到
Password for the [elastic] user successfully reset.
New value: 3_J35UWr2sIUkyxxxxxx
  • 現在驗證elastic能否正常響應
  • 在chrome瀏覽器的地址欄輸入https://localhost:9200
  • 此時瀏覽器會彈出安全提示,如下圖,這時候不要用滑鼠去點任何地方,直接在鍵盤上輸入thisisunsafe,然後回車
image-20220529193340940
  • 接下來就會彈出登錄頁面了,如下圖,填寫賬號elastic,密碼是剛纔控制台返回的
image-20220529111851813
  • 如果看到以下信息,證明es啟動成功
image-20220529112221897
  • 如果您在chrome上安裝了ElasticSearch Head插件(沒錯,是chrome瀏覽器插件),此時已經可以訪問es服務了,如下圖
image-20220529114326591
  • es已經就緒,接下來是kibana

部署和操作kibana

  • 一行命令完成部署
docker run \
--name kibana \
--net elastic \
-p 5601:5601 \
-idt kibana:8.2.2
  • 生成token,kibana連接es的時候要用到
docker exec -it es01 /usr/share/elasticsearch/bin/elasticsearch-create-enrollment-token -s kibana
  • 控制台會生成一長串文本,請保存下來,這是稍後給kibana用來連接es的token
  • 瀏覽器訪問http://localhost:5601/,會彈出輸入視窗,如下圖,在文本框內輸入剛纔生成的token內容,再點擊Configure Elastic按鈕
image-20220529165840254
  • 然後彈出個輸入驗證碼的頁面
image-20220529170157182
  • 在控制台輸入以下命令,順利拿到驗證碼
docker exec -it kibana bin/kibana-verification-code
  • 回到網頁輸入驗證碼,可以看到初始化頁面
image-20220529170304401
  • 接下來就是常規的安全登錄了,如下圖,輸入es的賬號密碼即可登錄成功
image-20220529170545388
  • 登錄成功,下圖選擇右邊的Explore on my own
image-20220529170724818
  • eshead顯示新增了一些kibana自用的索引
image-20220529204959621

集群擴容

  • 目前es服務是單節點,有時候需要對單節點進行擴容,加入新的機器以提升es服務的性能、存儲、可用性等,docker下可以很方便的進行擴容,接下來一起試試
  • 與kibana能夠訪問es類似,新機器加入當前es服務也需要授權token,生成token的命令如下,請在控制台執行
docker exec -it es01 /usr/share/elasticsearch/bin/elasticsearch-create-enrollment-token -s node
  • 拿到控制台生產的token後(30分鐘有效期),執行以下命令即可創建一個新的es容器,與原先的es組成集群,原有的數據會保留,註意將xxxxxx替換成剛剛生成的token
docker run \
-e ENROLLMENT_TOKEN="xxxxxx" \
-e ES_JAVA_OPTS="-Xms1024m -Xmx1024m" \
--name es02 \
--net elastic \
-idt elasticsearch:8.2.2
  • 在eshead上可以看到新增的節點
image-20220529205158965
  • 至此,kibana部署完成,接下來可以做一些CRUD的基本操作,新手可用來快速瞭解es基本操作,老司機可以直接跳過了

實戰es操作:命令行操作

  • 咱們先用命令行做一些最基本的操作,然後再考慮用kibana

  • 由於es開方的https服務,所以首先把證書從容器中導出來,後面的curl請求都要指定這個證書

docker cp es01:/usr/share/elasticsearch/config/certs/http_ca.crt .
  • 當前目錄下新增名為http_ca.crt的文件,就是安全證書了,試試能不能用,控制台輸入以下命令,註意把xxxxxx換成您自己的密碼
curl --cacert http_ca.crt -u elastic:xxxxxx https://localhost:9200
  • 控制台輸出以下信息,證明外部訪問es已經成功
❯ curl --cacert http_ca.crt -u elastic:xxxxxx https://localhost:9200
{
  "name" : "279acdab6c7f",
  "cluster_name" : "docker-cluster",
  "cluster_uuid" : "whfRDTzCQym_jwx2OrMgKg",
  "version" : {
    "number" : "8.2.2",
    "build_flavor" : "default",
    "build_type" : "docker",
    "build_hash" : "9876968ef3c745186b94fdabd4483e01499224ef",
    "build_date" : "2022-05-25T15:47:06.259735307Z",
    "build_snapshot" : false,
    "lucene_version" : "9.1.0",
    "minimum_wire_compatibility_version" : "7.17.0",
    "minimum_index_compatibility_version" : "7.0.0"
  },
  "tagline" : "You Know, for Search"
}
  • 建一個索引試試,此索引名為my-book,有六個欄位
curl -X PUT "https://localhost:9200/my-book?pretty" \
--cacert http_ca.crt \
-u elastic:xxxxxx \
-H 'Content-Type: application/json' \
-d'
{
  "settings": {
    "number_of_shards": 1
  },
  "mappings": {
    "properties": {
                "line_id": {
                    "type": "long"
                   },
                "line_number": {
                     "type": "keyword"
                },
               "play_name": {
                    "type": "keyword"
               },
               "speaker": {
                    "type": "keyword"
               },
               "speech_number": {
                    "type": "long"
               },
               "text_entry": {
                    "type": "text"
               }
          }
  }
}
'
  • 收到響應
{
  "acknowledged" : true,
  "shards_acknowledged" : true,
  "index" : "my-book"
}
  • eshead插件也能看到索引創建成功
image-20220529205948266
  • 用GET命令獲取索引信息試試,如下,符合預期
❯ curl -X GET \
https://localhost:9200/my-book\?pretty \
--cacert http_ca.crt \
-u elastic:m9ZRFl9wCIiVkLudRopy
{
  "my-book" : {
    "aliases" : { },
    "mappings" : {
      "properties" : {
        "line_id" : {
          "type" : "long"
        },
        "line_number" : {
          "type" : "keyword"
        },
        "play_name" : {
          "type" : "keyword"
        },
        "speaker" : {
          "type" : "keyword"
        },
        "speech_number" : {
          "type" : "long"
        },
        "text_entry" : {
          "type" : "text"
        }
      }
    },
    "settings" : {
      "index" : {
        "routing" : {
          "allocation" : {
            "include" : {
              "_tier_preference" : "data_content"
            }
          }
        },
        "number_of_shards" : "1",
        "provided_name" : "my-book",
        "creation_date" : "1653811101586",
        "number_of_replicas" : "1",
        "uuid" : "zX8kWS_IQ-ymdI7vYLOjew",
        "version" : {
          "created" : "8020299"
        }
      }
    }
  }
}
curl -H 'Content-Type: application/x-ndjson' \
--cacert http_ca.crt \
-u elastic:m9ZRFl9wCIiVkLudRopy \
-s -XPOST https://localhost:9200/_bulk \
--data-binary @shakespeare_only_one_type.json
  • 導入成功後,用eshead可以看到每條記錄的詳細信息

    image-20220529211718451
  • 接下來試試kibana

操作kibana

  • 在kibana頁面,點擊下圖紅框位置,進入查詢頁面
image-20220529212055604
  • 執行查詢的操作如下
image-20220529212603764
  • 看看剛剛導入了多少數據,如下圖,十一萬

image-20220529212926138

  • 至此,基於docker部署ElasticSearch-8和Kibana-8的實戰就完成了,希望本文能給您一些參考

歡迎關註博客園:程式員欣宸

學習路上,你不孤單,欣宸原創一路相伴...


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

-Advertisement-
Play Games
更多相關文章
  • 上一篇寫服務端的文章《MQTTnet4入門(一)實現服務端》已經是去年年底,現在MQTTnet的版本是4.2.1.781,總的來說改動不大。下麵以新版為例實現一個客戶端。 var mqttClientOptions = new MqttClientOptionsBuilder() .WithTcpS ...
  • 通過vmstat分析性能 如上圖所示,我們在命令vmstat後面添加了兩個參數,1表示間隔一秒獲取一次,10表示總共獲取10次 我們一列一列數據來看: r:代表目前實際運行的指令隊列,很高表示CPU很繁忙通常會CPU使用率過高 這個數據如果高於伺服器CPU核數就可能出現瓶頸(需要結合後五列CPU使用 ...
  • 之前實現的c語言項目單元測試框架cutest, 功能更新, 已上傳至ubuntu ppa倉庫, 方便安裝使用, 文末附帶視頻說明. ...
  • 引言 我們都知道,Redis 的數據存儲在記憶體中, 一旦伺服器宕機,記憶體中的數據將全部丟失。因此,對 Redis 來說,實現數據的持久化,避免從後端資料庫中進行恢復,是至關重要的。本篇我們詳細講解下 Redis 的三種持久化機制,分別是 AOF(Append Only File) 日誌和 RDB 快 ...
  • > Vue2.x使用EventBus進行組件通信,而Vue3.x推薦使用`mitt.js`。 > > > 比起Vue實例上的`EventBus`,`mitt.js`好在哪裡呢?首先它足夠小,僅有200bytes,其次支持全部事件的監聽和批量移除,它還不依賴Vue實例,所以可以跨框架使用,React或 ...
  • ![](https://img2023.cnblogs.com/blog/3076680/202308/3076680-20230817155723872-372310672.png) # 1. 基本信息 發佈!設計與部署穩定的分散式系統 第2版 Release It! Design and Dep ...
  • > 任何傻瓜都可以寫出電腦能懂的代碼,但好的程式員可以寫出人類能懂的代碼—–Martin Fowler 如果你是新手,你可能會問,為什麼代碼需要設計原則? 我想說的是肯定不是為了故作高深,存在即是合理。 如果寫了一個簡單的程式,你可能不需要設計原則。 如果你寫了一個複雜的,但是之後再也不會改,那麼 ...
  • 領域區域設計的分層架構模型其實是在不斷優化和發展的,從最早的傳統直腸子式的四層架構模型,逐漸演變成目前以依賴倒置為原則的新的四層架構模型,從而實現了各層對基礎設施層的解耦。 DDD中的分層架構很好的應用了[關註點分離原則](http://www.cnblogs.com/LittleFeiHu/p/6 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...