那曲檬骨新材料有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何為ClickHouse增強高可用能力

jf_ro2CN3Fa ? 來源:芋道源碼 ? 作者:芋道源碼 ? 2022-10-31 15:00 ? 次閱讀

相信大家都對大名鼎鼎的ClickHouse有一定的了解了,它強大的數據分析性能讓人印象深刻。但在字節大量生產使用中,發現了ClickHouse依然存在了一定的限制。例如:

缺少完整的upsert和delete操作

多表關聯查詢能力弱

集群規模較大時可用性下降(對字節尤其如此)

沒有資源隔離能力

因此,我們決定將ClickHouse能力進行全方位加強,打造一款更強大的數據分析平臺。后面我們將從五個方面來和大家分享,本篇將詳細介紹我們是如何為ClickHouse增強高可用能力的。

字節遇到的ClickHouse可用性問題

隨著字節業務的快速發展,產品快速擴張,承載業務的ClickHouse集群節點數也快速增加。另一方面,按照天進行的數據分區也快速增加,一個集群管理的庫表特別多,開始出現元數據不一致的情況。兩方面結合,導致集群的可用性極速下降,以至于到了業務難以接受的程度。直觀的問題有三類:

1、故障變多

典型的例子如硬件故障,幾乎每天都會出現。另外,當集群達到一定的規模,Zookeeper會成為瓶頸,增加故障發生頻率。

2、故障恢復時間長

因為數據分區變多,導致一旦發生故障,恢復時間經常會需要1個小時以上,這是業務方完全不能接受的。

3、運維復雜度提升

以往只需要一個人負責運維的集群,由于節點增加和分區變多,運維復雜度和難度成倍的增加,目前運維人數增加了幾人也依然拙荊見肘,依然難保證集群的穩定運行。

可用性問題已經成為制約業務發展的重要問題,因此我們決定將影響高可用的問題一一拆解,并逐個解決。

提升高可用能力的方案

一、降低Zookeeper壓力

問題所在:

原生ClickHouse 使用 ReplicatedMergeTree 引擎來實現數據同步。原理上,ReplicatedMergeTree 基于 ZooKeeper 完成多副本的選主、數據同步、故障恢復等功能。由于 ReplicatedMergeTree 對 ZooKeeper 的使用比較重,除了每組副本一些表級別的元信息,還存儲了邏輯日志、part 信息等潛在數量級較大的信息。Zookeeper并不是一個能做到良好線性擴展的系統,當ZooKeeper 在相對較高的負載情況下運行時,往往性能表現并不佳,甚至會出現副本無法寫入,數據也無法同步的情況。在字節內部實際使用和運維 ClickHouse 的過程中,ZooKeeper 也是非常容易成為一個瓶頸的組件。

改造思路:

ReplicatedMergeTree 支持 insert_quorum,insert_quorum 是指如果副本數為3,insert_quorum=2,要成功寫入至少兩個副本才會返回寫入成功。

新分區在副本之間復制的流程如下:

50fa4c68-58c2-11ed-a3b6-dac502259ad0.png

可以看到,反復在 zookeeper 中進行分發日志、數據交換等步驟,這正是引起瓶頸的原因之一。

為了降低對 ZooKeeper 的負載,在ByteHouse中重新實現了一套 HaMergeTree 引擎。通過HaMergeTree降低對 ZooKeeper 的請求次數,減少在 ZooKeeper 上存儲的數據量,新的 HaMergeTree 同步引擎:

1)保留ZooKeeper上表級別的元信息;

2)簡化邏輯日志的分配;

3)將 part 信息從 ZooKeeper 日志移除。

5109eff6-58c2-11ed-a3b6-dac502259ad0.png

HaMergeTree 減少了操作日志等信息在zookeeper里面的存放,來減少zookeeper的負載,zookeeper里面只是存放log LSN, 具體日志在副本之間通過gossip協議同步回放。

在保持和ReplicatedMergeTree完全兼容的前提下,新的 HaMergeTree 極大減輕了對 ZooKeeper 的負載,實現了 ZooKeeper 集群的壓力與數據量不相關。上線后,因Zookeeper導致的異常大量減少。無論是單集群幾百甚至上千節點,還是單節點上萬張表,都能保障良好的穩定性。

二、提升故障恢復能力

問題所在:

雖然所有數據從業者都在做各種努力,想要保證線上生產環境不出故障,但是現實中還是難以避免會遇到各式各樣的問題。主要是由下面這幾種因素引起的:

軟件缺陷:軟件設計本身的Bug引起的系統非正常終止,或依賴的組件兼容引發的問題。

硬件故障:常見的有磁盤損壞、內容故障、CPU故障等,當集群規模擴大后發生的頻率也線性增加。

內存溢出導致進程被停止:在OLAP數據庫中經常發生。

意外因素:如斷電、誤操作等引發的問題。

由于原生ClickHouse希望達到極致性能的初衷,所以在ClickHouse系統中元數據常駐于內存中,這導致了ClickHouse server重啟時間非常長。因而當故障發生后,恢復的時間也很長,動輒一到兩個小時,相當于業務也要中斷一到兩個小時。當故障頻繁出現,造成的業務損失是無法估量的。

改造思路:

為了解決上述問題,在ByteHouse中采用了元數據持久化的方案,將元數據持久化到RocksDB, Server啟動時直接從RocksDB加載元數據,內存中也僅僅存放必要的Part信息。因此可以減少元數據對內存的占用,以及加速集群的啟動以及故障恢復時間。

如下圖所示,元數據持久化整體上采用了RocksDB+Meta in Memory的方式,每個Table都會對應一個RocksDB數據庫存放該表所有Part的元信息。Table首次啟動時,從文件系統中加載的Part元數據將被持久化到RocksDB中;之后重啟時就可以直接從RocksDB中加載Part。每個表從RocksDB或者文件系統加載的Part將只在內存中存放必要的Part信息。在實際使用Part時,將通過內存中存放的Part元信息去RocksDB中讀取并加載對應Part。

51256fe2-58c2-11ed-a3b6-dac502259ad0.png

完成元數據持久化后,在性能基本無損失的情況下,單機支持的part不再受內存容量的限制,可以達到100萬以上。最重要的是,故障恢復的時間顯著縮短,只需要此前的幾十分之一的時間就可以完成。例如在原生ClickHouse中需要一到兩個小時的恢復時間,在ByteHouse中只需要3分鐘,大大提高的系統的高可用能力,為業務提供了堅實保障。

三、其他方面

除了以上兩點,在ByteHouse中在其他很多方面都為高可用能力做了增強,如通過HaKafka引擎提升了數據寫入的高可用性,提升實時數據寫入的容錯率,可自動切換主備寫入;增加了監控運維平臺,實現對關鍵指標的監控、告警;增加多種問題診斷工具,能實現故障的快速定位。

對于數據分析平臺來說,穩定性是重中之重。我們對ByteHouse的高可用能力的提升是不會停止的,在極致性能的背后,力圖為用戶提供最強有力的穩定性保障。

審核編輯:彭靜
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • cpu
    cpu
    +關注

    關注

    68

    文章

    10905

    瀏覽量

    213030
  • 存儲
    +關注

    關注

    13

    文章

    4355

    瀏覽量

    86177
  • 數據分析
    +關注

    關注

    2

    文章

    1461

    瀏覽量

    34166

原文標題:ByteHouse實踐與思考:如何補全ClickHouse高可用短板?

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    大數據實時分析領域的ClickHouse

    ClickHouse大數據實時分析領域的黑馬
    發表于 03-24 11:09

    Centos7下如何搭建ClickHouse列式存儲數據庫

    理,以此來使用當前服務器上可用的所有資源。(5)多服務器分布式處理在ClickHouse中,數據可以保存在不同的shard上,每一個shard都由一組用于容錯的replica組成,查詢可以并行的在所
    發表于 01-05 18:03

    何為電壓測試選擇最佳電纜?

    何為電壓測試選擇最佳電纜?
    發表于 05-11 06:44

    重新增強可用性縮減IT基礎設施模型

    重新增強可用性縮減 IT 基礎設施模型
    發表于 01-06 17:33 ?0次下載

    重新增強可用性縮減 IT 基礎設施模型

    voico 重新增強可用性縮減 IT 基礎設施模型
    發表于 06-02 15:41 ?0次下載

    阿里云應用可用服務公測發布

    產品介紹:?應用可用服務 AHAS 是一款專注于提高應用可用能力的 SaaS 產品,提供應用架構自動探測、故障注入式
    發表于 11-28 16:20 ?311次閱讀

    PB級分析型數據庫ClickHouse的應用場景和特性等分享

    在百花齊放的交互式分析領域,ClickHouse 絕對是后起之秀,它雖然年輕,卻有非常大的發展空間。本文將分享 PB 級分析型數據庫 ClickHouse 的應用場景、整體架構、眾多核心特性等,幫助
    的頭像 發表于 03-30 10:36 ?7638次閱讀
    PB級分析型數據庫<b class='flag-5'>ClickHouse</b>的應用場景和特性等分享

    可用增強型產品

    可用增強型產品
    發表于 04-24 13:56 ?0次下載
    <b class='flag-5'>可用</b>的<b class='flag-5'>增強</b>型產品

    ClickHouse和Elasticsearch壓測對比

    ClickHouse 是一個真正的列式數據庫管理系統(MS)。在 ClickHouse 中,數據始終是列存儲的,包括向量(對或列塊)的執行過程。只要有可能,操作都是基于向量進行分派的,而不是實現的價值,這被稱為?它有查詢實際的數據處理?。
    的頭像 發表于 09-15 15:49 ?1441次閱讀

    火山引擎:ClickHouse增強計劃之“Upsert”

    性能下降嚴重,ReplacingMergeTree采用的是寫優先的設計邏輯,這導致讀性能損失嚴重。表現是在進行查詢時性能較ClickHouse其他引擎的性能下降嚴重,涉及ReplacingMergeTree的查詢響應時間過慢。
    的頭像 發表于 09-22 14:26 ?1791次閱讀

    替代ELK:ClickHouse+Kafka+FlieBeat才是最絕的

    來源:juejin.cn/post/7120880190003085320 背景 Elasticsearch 與 ClickHouse 成本分析 環境部署 總結 ? 背景 saas業務業務未來需要
    的頭像 發表于 10-09 17:41 ?2100次閱讀

    火山引擎:ClickHouse增強計劃之“多表關聯查詢”

    和delete操作 ? 多表關聯查詢能力弱 ? 集群規模較大時可用性下降(對字節尤其如此) ? 沒有資源隔離能力 因此,我們決定將ClickHouse
    的頭像 發表于 10-10 17:00 ?1649次閱讀

    ClickHouse增強計劃之“資源隔離”

    ClickHouse的資源管控能力不夠完善,在 insert、select 并發的場景下會導致執行失敗,影響用戶體驗。這是因為社區版ClickHouse目前僅提供依據不同用戶的最大內
    的頭像 發表于 11-07 10:25 ?922次閱讀

    如何增強MOS管的帶載能力呢?

    如何增強MOS管的帶載能力呢? 增強MOS管的帶載能力是通過優化器件的設計和選擇適合的工作條件來實現的。下面將詳細介紹如何增強MOS管的帶載
    的頭像 發表于 01-12 14:43 ?1143次閱讀

    供應鏈場景使用ClickHouse最佳實踐

    關于ClickHouse的基礎概念這里就不做太多的贅述了,ClickHouse官網都有很詳細說明。結合供應鏈數字化團隊在使用ClickHouse時總結出的一些注意事項,尤其在命名方面要求研發嚴格遵守
    的頭像 發表于 07-18 15:05 ?334次閱讀
    供應鏈場景使用<b class='flag-5'>ClickHouse</b>最佳實踐
    德州扑克入门与提高| 百家乐筹码订做| 网上娱乐城排名| 百家乐打印程序| 离岛区| 百家乐官网怎样捉住长开| 无锡百家乐的玩法技巧和规则| 百家乐官网网络游戏平台| 太阳城网上娱乐城| 最可信百家乐官网娱乐城| 安溪县| 百家乐麻将筹码币| 乐中百家乐的玩法技巧和规则 | 百家乐官网的弱点| 威尼斯娱乐| 百家乐网络娱乐场开户注册| 百家乐官网存1000送| 水果机赌博| 百家乐开户过的路纸| 财神娱乐城信誉| 现金百家乐破解| 澳门百家乐官网网上赌博| 大发888游戏平台dafa 888 gw| 百家乐最好打法与投注| 百家乐官网游戏介绍与分析| 邻水| 百家乐视频裸聊| 锡林郭勒盟| 百威百家乐的玩法技巧和规则| 24山方向上| 肯博百家乐官网游戏| 娱乐城百家乐可以代理吗 | 环球百家乐的玩法技巧和规则| 综合百家乐官网博彩论坛| 玩百家乐官网游戏经验| 516棋牌游戏下载| 百家乐博弈指数| 属虎和属猴牛人做生意| 百家乐官网赌机玩法| 澳门百家乐官网皇冠网| 鼎龙娱乐城开户|