91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構

      手機站
      千鋒教育

      千鋒學習站 | 隨時隨地免費學

      千鋒教育

      掃一掃進入千鋒手機站

      領取全套視頻
      千鋒教育

      關注千鋒學習站小程序
      隨時隨地免費學習課程

      當前位置:首頁  >  技術干貨  > ES底層數(shù)據(jù)持久化的過程?

      ES底層數(shù)據(jù)持久化的過程?

      來源:千鋒教育
      發(fā)布人:wjy
      時間: 2022-09-19 16:30:11 1663576211

        通過分步驟看數(shù)據(jù)持久化過程:write -> refresh -> flush -> merge

        write 過程

      ES底層數(shù)據(jù)持久化的過程1

       

        一個新文檔過來,會存儲在 in-memory buffer 內(nèi)存緩存區(qū)中,順便會記錄 Translog(Elasticsearch 增加了一個 translog ,或者叫事務日志,在每一次對 Elasticsearch 進行操作時均進行了日志記錄)。

        這時候數(shù)據(jù)還沒到 segment ,是搜不到這個新文檔的。數(shù)據(jù)只有被 refresh 后,才可以被搜索到。

        refresh 過程

      ES底層數(shù)據(jù)持久化的過程2

       

        refresh 默認 1 秒鐘,執(zhí)行一次上圖流程。ES 是支持修改這個值的,通過 index.refresh_interval 設置 refresh (沖刷)間隔時間。refresh 流程大致如下:

        1.in-memory buffer 中的文檔寫入到新的 segment 中,但 segment 是存儲在文件系統(tǒng)的緩存中。此時文檔可以被搜索到

        2.最后清空 in-memory buffer。注意: Translog 沒有被清空,為了將 segment 數(shù)據(jù)寫到磁盤

        3.文檔經(jīng)過 refresh 后, segment 暫時寫到文件系統(tǒng)緩存,這樣避免了性能 IO 操作,又可以使文檔搜索到。refresh 默認 1 秒執(zhí)行一次,性能損耗太大。一般建議稍微延長這個 refresh 時間間隔,比如 5 s。因此,ES 其實就是準實時,達不到真正的實時。

        flush 過程

        每隔一段時間—例如 translog 變得越來越大—索引被刷新(flush);一個新的 translog 被創(chuàng)建,并且一個全量提交被執(zhí)行

      ES底層數(shù)據(jù)持久化的過程3

       

        上個過程中 segment 在文件系統(tǒng)緩存中,會有意外故障文檔丟失。那么,為了保證文檔不會丟失,需要將文檔寫入磁盤。那么文檔從文件緩存寫入磁盤的過程就是 flush。寫入磁盤后,清空 translog。具體過程如下:

        所有在內(nèi)存緩沖區(qū)的文檔都被寫入一個新的段。緩沖區(qū)被清空。一個Commit Point被寫入硬盤。文件系統(tǒng)緩存通過 fsync 被刷新(flush)。老的 translog 被刪除。

        merge 過程

        由于自動刷新流程每秒會創(chuàng)建一個新的段 ,這樣會導致短時間內(nèi)的段數(shù)量暴增。而段數(shù)目太多會帶來較大的麻煩。 每一個段都會消耗文件句柄、內(nèi)存和cpu運行周期。更重要的是,每個搜索請求都必須輪流檢查每個段;所以段越多,搜索也就越慢。

        Elasticsearch通過在后臺進行Merge Segment來解決這個問題。小的段被合并到大的段,然后這些大的段再被合并到更大的段。

        當索引的時候,刷新(refresh)操作會創(chuàng)建新的段并將段打開以供搜索使用。合并進程選擇一小部分大小相似的段,并且在后臺將它們合并到更大的段中。這并不會中斷索引和搜索。

      ES底層數(shù)據(jù)持久化的過程4

       

        一旦合并結束,老的段被刪除:

        新的段被刷新(flush)到了磁盤。 ** 寫入一個包含新段且排除舊的和較小的段的新提交點。新的段被打開用來搜索。老的段被刪除。

      ES底層數(shù)據(jù)持久化的過程5

        合并大的段需要消耗大量的I/O和CPU資源,如果任其發(fā)展會影響搜索性能。Elasticsearch在默認情況下會對合并流程進行資源限制,所以搜索仍然 有足夠的資源很好地執(zhí)行。

      tags:
      聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強師集結,手把手帶你蛻變精英
      請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
      免費領取
      今日已有369人領取成功
      劉同學 138****2860 剛剛成功領取
      王同學 131****2015 剛剛成功領取
      張同學 133****4652 剛剛成功領取
      李同學 135****8607 剛剛成功領取
      楊同學 132****5667 剛剛成功領取
      岳同學 134****6652 剛剛成功領取
      梁同學 157****2950 剛剛成功領取
      劉同學 189****1015 剛剛成功領取
      張同學 155****4678 剛剛成功領取
      鄒同學 139****2907 剛剛成功領取
      董同學 138****2867 剛剛成功領取
      周同學 136****3602 剛剛成功領取
      相關推薦HOT