ClickHouse與 Elasticsearch聚合性能對比測試

概述

Elasticsearch以其優(yōu)秀的分布式架構(gòu)與全文搜索引擎等特點在機器數(shù)據(jù)的存儲蔗彤、分析領(lǐng)域廣為使用孝扛,但隨著數(shù)據(jù)量的增長舀锨,其聚合分析性能已無法滿足業(yè)務(wù)需求蝇更。而ClickHouse作為一個高性能的OLAP列式數(shù)據(jù)庫管理系統(tǒng)有望解決這一痛點沪编。

本文是對ClickHouse與Elasticsearch聚合性能的簡單對比測試。主要關(guān)注查詢語句的響應(yīng)時間年扩,暫不考慮資源占用情況蚁廓。

測試環(huán)境

組件 版本 CPU 內(nèi)存
ClickHouse 7.9.0 4C 8G
Elasticsearch 20.11.4.13 4C 8G

使用ClickHouse官方提供的測試數(shù)據(jù)集,共67G常遂,約6億行纳令。


測試數(shù)據(jù)集.png

其中,ClickHouse使用LO_ORDERDATE字段作為分區(qū)鍵克胳,使用LO_ORDERDATE, LO_ORDERKEY作為排序鍵平绩。

測試內(nèi)容

某字段出現(xiàn)次數(shù)TOP 10

# ClickHouse
SELECT LO_SHIPMODE,COUNT() FROM lineorder GROUP BY LO_SHIPMODE ORDER BY COUNT() DESC LIMIT 10

# Elasticsearch
GET lineorder/_search
{
  "aggs": {
    "1": {
      "terms": {
        "field": "LO_SHIPMODE.keyword",
        "order": {
          "_count": "desc"
        },
        "size": 10
      }
    }
  },
  "size": 0
}

某字段按年進行計數(shù)


# ClickHouse
SELECT toYear(LO_ORDERDATE),COUNT() FROM lineorder GROUP BY toYear(LO_ORDERDATE) FORMAT PrettyCompactMonoBlock

# Elasticsearch
GET lineorder/_search
{
  "aggs": {
    "2": {
      "date_histogram": {
        "field": "LO_ORDERDATE",
        "calendar_interval":"1y",
        "format":"yyyy-MM-dd"
      }
    }
  },
  "size": 0
}

多個字段按年進行統(tǒng)計


# ClickHouse
SELECT LO_ORDERDATE,LO_ORDERKEY,LO_SHIPMODE,LO_ORDERPRIORITY,LO_COMMITDATE FROM lineorder WHERE LO_ORDERDATE >= '1992-01-01' AND LO_ORDERDATE < '1993-01-01' ORDER BY LO_ORDERDATE  LIMIT 500

# Elasticsearch
GET lineorder/_search
{
  "size": 500,
  "sort": [
    {
      "timestamp": {
        "order": "desc",
        "unmapped_type": "boolean"
      }
    }
  ],
  "query": {
    "bool": {
      "must": [],
      "filter": [
        {
          "match_all": {}
        },
        {
          "match_all": {}
        },
        {
          "range": {
            "LO_ORDERDATE": {
              "gte": "1992-01-01",
              "lte": "1993-01-01",
              "format": "strict_date_optional_time"
            }
          }
        }
      ],
      "should": [],
      "must_not": []
    }
  }
}

基于時間的多字段聚合


# ClickHouse
SELECT toYear(LO_ORDERDATE),LO_SHIPMODE,COUNT() FROM lineorder GROUP BY toYear(LO_ORDERDATE),LO_SHIPMODE ORDER BY toYear(LO_ORDERDATE) FORMAT PrettyCompactMonoBlock

# Elasticsearch
GET lineorder/_search
{
  "aggs": {
    "3": {
      "terms": {
        "field": "LO_SHIPMODE.keyword",
        "order": {
          "_count": "desc"
        },
        "size": 10
      },
      "aggs": {
        "2": {
          "date_histogram": {
            "field": "LO_ORDERDATE",
            "calendar_interval": "1y",
            "time_zone": "Asia/Shanghai",
            "min_doc_count": 1
          }
        }
      }
    }
  },
  "size": 0
}

基于時間的多字段聚合


# ClickHouse
SELECT toYear(LO_ORDERDATE),LO_SHIPMODE,COUNT() FROM lineorder GROUP BY toYear(LO_ORDERDATE),LO_SHIPMODE ORDER BY toYear(LO_ORDERDATE) FORMAT PrettyCompactMonoBlock

# Elasticsearch
GET lineorder/_search
{
  "aggs": {
    "3": {
      "terms": {
        "field": "LO_SHIPMODE.keyword",
        "order": {
          "_count": "desc"
        },
        "size": 10
      },
      "aggs": {
        "2": {
          "date_histogram": {
            "field": "LO_ORDERDATE",
            "calendar_interval": "1y",
            "time_zone": "Asia/Shanghai",
            "min_doc_count": 1
          }
        }
      }
    }
  },
  "size": 0
}

聚合嵌套(非時間字段)


# ClickHouse
SELECT LO_SHIPMODE,COUNT(LO_SHIPMODE),LO_ORDERPRIORITY,COUNT(LO_ORDERPRIORITY) FROM lineorder GROUP BY LO_SHIPMODE,LO_ORDERPRIORITY ORDER BY COUNT(LO_SHIPMODE),COUNT(LO_ORDERPRIORITY) LIMIT 5 BY LO_SHIPMODE,LO_ORDERPRIORITY

# Elasticsearch
GET lineorder/_search
{
  "aggs": {
    "2": {
      "terms": {
        "field": "LO_SHIPMODE.keyword",
        "order": {
          "_count": "desc"
        },
        "size": 5
      },
      "aggs": {
        "3": {
          "terms": {
            "field": "LO_ORDERPRIORITY.keyword",
            "order": {
              "_count": "desc"
            },
            "size": 5
          }
        }
      }
    }
  },
  "size": 0
}

測試結(jié)論

聚合場景 ClickHouse(ms) Elasticsearch(ms) 性能對比
基于時間的多字段聚合 5506 15599 近3倍
多個字段按年進行計數(shù)(數(shù)據(jù)表) 381 6267 16倍多
某字段出現(xiàn)次數(shù) TOP 10(餅圖) 4048 7317 近2倍
某字段按年進行計數(shù)(時間趨勢圖) 901 23257 25倍多
聚合嵌套(非時間字段) 6937 15767 2倍多

相同數(shù)據(jù)量下,ClickHouse的聚合性能都要優(yōu)于Elasticsearch漠另,且如果基于排序鍵進行聚合捏雌,性能更好,是ES的數(shù)倍笆搓。
此外性湿,ClickHouse的SummaryMergeTree纬傲、AggregatingMergeTree表引擎支持后臺自動聚合數(shù)據(jù),所以在某些場景下其聚合分析性能會更優(yōu)肤频。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末叹括,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子宵荒,更是在濱河造成了極大的恐慌汁雷,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件报咳,死亡現(xiàn)場離奇詭異侠讯,居然都是意外死亡,警方通過查閱死者的電腦和手機暑刃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評論 3 385
  • 文/潘曉璐 我一進店門厢漩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人岩臣,你說我怎么就攤上這事溜嗜。” “怎么了婿脸?”我有些...
    開封第一講書人閱讀 158,369評論 0 348
  • 文/不壞的土叔 我叫張陵粱胜,是天一觀的道長。 經(jīng)常有香客問我狐树,道長,這世上最難降的妖魔是什么鸿脓? 我笑而不...
    開封第一講書人閱讀 56,799評論 1 285
  • 正文 為了忘掉前任抑钟,我火速辦了婚禮,結(jié)果婚禮上野哭,老公的妹妹穿的比我還像新娘在塔。我一直安慰自己,他們只是感情好拨黔,可當(dāng)我...
    茶點故事閱讀 65,910評論 6 386
  • 文/花漫 我一把揭開白布蛔溃。 她就那樣靜靜地躺著,像睡著了一般篱蝇。 火紅的嫁衣襯著肌膚如雪贺待。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,096評論 1 291
  • 那天零截,我揣著相機與錄音麸塞,去河邊找鬼。 笑死涧衙,一個胖子當(dāng)著我的面吹牛哪工,可吹牛的內(nèi)容都是我干的奥此。 我是一名探鬼主播,決...
    沈念sama閱讀 39,159評論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼雁比,長吁一口氣:“原來是場噩夢啊……” “哼稚虎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起偎捎,我...
    開封第一講書人閱讀 37,917評論 0 268
  • 序言:老撾萬榮一對情侶失蹤蠢终,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后鸭限,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蜕径,經(jīng)...
    沈念sama閱讀 44,360評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,673評論 2 327
  • 正文 我和宋清朗相戀三年败京,在試婚紗的時候發(fā)現(xiàn)自己被綠了兜喻。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,814評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡赡麦,死狀恐怖朴皆,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情泛粹,我是刑警寧澤遂铡,帶...
    沈念sama閱讀 34,509評論 4 334
  • 正文 年R本政府宣布,位于F島的核電站晶姊,受9級特大地震影響扒接,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜们衙,卻給世界環(huán)境...
    茶點故事閱讀 40,156評論 3 317
  • 文/蒙蒙 一钾怔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蒙挑,春花似錦宗侦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至馋袜,卻和暖如春男旗,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背桃焕。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評論 1 267
  • 我被黑心中介騙來泰國打工剑肯, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人观堂。 一個月前我還...
    沈念sama閱讀 46,641評論 2 362
  • 正文 我出身青樓让网,卻偏偏與公主長得像呀忧,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子溃睹,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,728評論 2 351

推薦閱讀更多精彩內(nèi)容