日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 單片機 > 架構師社區(qū)
[導讀]作者:cdai來源:blog.csdn.net/dc_726/article/details/942528501.近實時搜索1.1實時與近實時實時搜索(Real-timeSearch)很好理解,對于一個數據庫系統,執(zhí)行插入以后立刻就能搜索到剛剛插入到數據。而近實時(NearRea...

作者:cdai

來源:blog.csdn.net/dc_726/article/details/94252850


1.近實時搜索

1.1 實時與近實時

實時搜索(Real-time Search)很好理解,對于一個數據庫系統,執(zhí)行插入以后立刻就能搜索到剛剛插入到數據。而近實時(Near Real-time),所謂“近”也就是說比實時要慢一點點。

1.2 近實時的挑戰(zhàn)

對于一個單機系統來說,這也并不容易實現,因為還要保證數據的持久化,還要利用緩存等技術加快數據的訪問(注:這里不討論內存計算系統)。對于ElasticSearch這樣一個分布式系統,保證持久化的同時,還要初始化好用于全文檢索的內部數據結構,做到近實時的難度可想而知。而這就是ElasticSearch大獲成功的地方,也正是本文所要學習的主題:ElasticSearch是如何解決這些實現近實時搜索的難題的。

2.ElasticSearch的實現

2.1 不可變的數據結構

有經驗的程序員一定知道,在做并發(fā)編程時,控制可變數據的并發(fā)訪問是個難題。古往今來,各種粗細粒度的鎖,信號量,Actor模型等概念層出不窮。而另一流派函數式編程更為徹底,尤其是純函數式比如Haskell,用不可變數據來徹底解決這個問題。
在ElasticSearch這樣主要服務全文檢索的系統中,Inverted Index是核心數據結構。這里簡單說一句,Inverted Index本質上一組document中term的各種統計信息,比如最重要的詞頻,以及其他許多統計信息,比如文檔長度,詞序等等。要做到近實時搜索,就要保證新數據能快速構建,已有數據能被高速訪問。解決問題的關鍵就在于Inverted Index的不可變性,這也是ElasticSearch底層依賴的高性能Lucene的根本奧秘。

2.2 從不可變到可變

所以當用戶向ElasticSearch中的數據庫插入一組document后,底層Lucene構建出一個不可變的Inverted Index??晌覀冎溃粋€數據庫不可能是靜態(tài)的,當用戶再次插入新數據時,Lucene該怎樣處理呢?答案就是增量保存和邏輯標記。

所謂增量保存就是為新數據構建一個新的不可變的Inverted Index,當執(zhí)行搜索時,要合并每個Inverted Index中的統計信息得到最終結果。保存新數據的問題解決了,而邏輯標記就是解決更新和刪除的。Lucene為每個Inverted Index都額外維護一個del數據結構,當執(zhí)行刪除時,只需在del中標記,這樣最終結果就會排出掉刪除掉document。同理,更新時也是給老數據做標記,新document會保存在新的Inverted Index中,最終結果會使用最新版本數據的統計信息。在Lucene中,每個Inverted Index叫做Segment,而管理這些Segment的叫做Index。
ElasticSearch中一個數據庫被稱為Index,每個Index可以在創(chuàng)建時指定要劃分為幾份,每一份叫做Shard。Shard會被ElasticSearch分配到不同結點,運行中還會根據壓力做Rebalance。這個Shard其實就是Lucene中的Index。由于不同層級上名字的重復,初學時很容易混淆。

這種思想其實并非獨創(chuàng),在其他一些高級數據結構中也能找到它的影子。如果沒記錯的話,一個經典的例子就是LSM樹:https://en.m.wikipedia.org/wiki/Log-structured_merge-tree。

2.3 分布式數據存儲

對于分布式的數據存儲,ElasticSearch采取了經典的做法,對數據進行分片和路由,這里每個分片Shard就是一個Lucene數據庫Index。對于有副本replica的Shard,ElasticSearch操作完primary后,再去同步到replica。

2.4 挑戰(zhàn)磁盤I/O

現在我們已經可以高效地維護全文檢索的數據結構,也遵循經典做法解決了分布式數據存儲??删拖袂懊嫣岬降?,還有個挑戰(zhàn)就是磁盤讀寫的巨大開銷。Lucene的做法是,每個Segment在文件系統Cache中構建起來就可以被訪問,同步到磁盤的fsync之后才會執(zhí)行。Lucene的Index內部的Commit Point會記住哪些Segment還未同步。ElasticSearch默認每隔1秒會用Buffer中的document新建一個Segment,這個操作叫做refresh。正因為這1秒鐘的間隔,ElasticSearch支持的是近實時而非實時。

一個很自然的問題就是每秒鐘都會新建一個Segment,那Lucene Index中的Segment個數豈不是很容易就爆炸了。每個Segment都是一個物理文件,操作系統中打開文件的句柄個數是有限的,而且即便不考慮上限,過多Segment也會拖慢搜索,因為前面講過一次搜索的最終結果是要合并所有Segment中的統計信息的。
ElasticSearch的做法是維護一個后臺線程去做Merge,Merge的過程中不僅將多個小Segment合并成大的,同時還會排除掉刪除或修改的文件的老版本,最終修改Commit Point排除掉老的Segment,這樣那些“垃圾”document就徹底被刪除了。得益于Segment的不可變性,后臺進程Merge時并不會影響數據插入和搜索的性能。

2.5 保證數據不丟失

一個可以預料到的問題就是,如果當前結點上的ElasticSearch進程意外中止,那Buffer中等待處理的document和未同步到磁盤的Segment中的數據都會丟失。為了避免這一點,ElasticSearch引入了傳統數據庫中所謂的Write-Ahead Log(WAL)日志,ElasticSearch為其起名為translog。每次插入Buffer時,都會同時寫入translog。下面的圖示清晰地展示ElasticSearch是如何與Lucene配合的。

當創(chuàng)建新Segment時,Buffer清空,但translog會一直保留到Segment同步到磁盤才會清空。**所以當ElasticSearch重啟時,先根據Commit Point將所有之前已經commit到磁盤的Segment恢復到Cache,然后再重放(replay)translog中的所有操作。默認每30分鐘或者translog很大時,ElasticSearch做一次full commit,即flush操作。
繼續(xù)刨根問底,translog保證了Buffer和Segment的安全,誰來保證它的安全呢?默認情況下,translog每5秒鐘會同步到磁盤,也就是說我們至多會丟失5秒到數據。因為translog只是原始的請求document,所以這里的寫磁盤開銷是遠小于Segment的一次commit的。

3.題外話:如何深入學習ElasticSearch

以本文為例,談一談如何學習ElasticSearch。在有了一些分布式系統和開發(fā)經驗后,像本文2.3和2.5節(jié)是完全可以跳過的。前者是分布式系統的通用做法,而后者則早已存在于傳統數據庫中。要掌握ElasticSearch,基本用法和系統命令是一方面,而設計中的精華往往在前文2.1和2.2中。光理解了設計還不行,就像前面說過的,思想可能流傳已久,但做出來東西的質量則可能千差萬別。“天下大事,必做于細”,實現中的精髓只能在源代碼中體會。

其實這種方法在另一篇文章里也提到過,就是學一門編程語言時也是要抓住它的精髓,而不是每門語言都花很多時間去學基本語法,而沒有精力去掌握精華,最終迷失了。在此再次強調一下,自己也引以為戒。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯系該專欄作者,如若文章內容侵犯您的權益,請及時聯系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統 散熱

根據LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統,而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉