企業(yè)無論是已經(jīng)使用了開源日志收集工具,還是準備選擇一款或多款工具,都有必要了解日志收集工具的關鍵要求。這些要求包括:高數(shù)據(jù)吞吐量、可靠性、可擴展性、靈活性、安全性以及資源(CPU和內(nèi)存)消耗等。本文討論了市面上流行的幾款日志收集工具(包括 Logstash、Fluentd、Fluent Bit 和 Vector)及其主要特點。
1. Logstash
Logstash
是最受歡迎的日志收集工具之一,它是 ELK(Elasticsearch/Logstash/Kibana)架構(gòu)的一部分。
Logstash 的主要優(yōu)勢:
● 處理結(jié)構(gòu)化數(shù)據(jù)和非結(jié)構(gòu)化數(shù)據(jù)。
● 支持更高的數(shù)據(jù)安全性,能夠匿名化或排除敏感字段。
● 支持數(shù)百個插件,包括輸入、過濾和輸出等插件。過濾器插件執(zhí)行日志處理,比如聚合和解析。
雖然 Logstash 是一款可靠的日志收集工具,在處理日志數(shù)據(jù)方面有諸多選項,但如果內(nèi)存占用量小是個關鍵要求,本文介紹的其他日志收集工具可能更勝一籌。因為 Logstash 是用 Java 編寫的,所以需要 JVM 支持。如果企業(yè)打算從嵌入式設備和物聯(lián)網(wǎng)應用程序收集日志,它不是最佳選擇。
2. Fluentd
Fluentd
是一款日志收集工具,內(nèi)存占用量小,可以處理各種日志源和目的地。許多受支持的插件允許連接到多種類型的日志源和目的地。與其他日志收集工具一樣,F(xiàn)luentd 的典型日志源包括應用程序、基礎設施和消息隊列平臺,而通常目的地是日志管理工具和存儲歸檔系統(tǒng)。
Fluentd 的主要優(yōu)勢:
● 支持許多日志源和目的地。
● 靈活、可擴展的解析選項,支持多種輸入格式。
● 擁有龐大的生態(tài)系統(tǒng),包括成百上千個插件,以及用Ruby自行編寫插件的功能。
● 支持 Apache 許可證,版本2.0。
● 供應商中立(CNCF項目)。
如果企業(yè)需要中立的供應商,F(xiàn)luentd 是不錯的選擇。它還經(jīng)常與 Kubernetes 和容器化環(huán)境一起使用。
3. Fluent Bit
Fluent Bit
不僅是一款日志收集工具,還可以用作數(shù)據(jù)流處理工具,并充當將日志數(shù)據(jù)轉(zhuǎn)發(fā)到 Fluentd 的運送工具。Fluent Bit 在 Kubernetes 集群等容器化環(huán)境中運行順暢。Fluent Bit 可以擴展并仍能節(jié)省資源,因為它占用的空間很小。雖然 Fluent Bit 經(jīng)常用在 Kubernetes 環(huán)境中,但它也可以部署在裸機服務器、虛擬機和嵌入式設備上。
Fluent Bit的主要優(yōu)勢:
● 輕量級設計,內(nèi)存占用量極?。ㄍǔ2坏?MB)。
● 易于擴展的架構(gòu)。
● 可插入式架構(gòu),有許多輸入、過濾器和輸出插件。
● 支持基于指標和基于日志的有效負載。
● 支持通過安全的連接將日志發(fā)送到存儲后端。
● 使用 SQL,支持數(shù)據(jù)流處理。
● 支持 Apache 許可證,版本2.0。
● 供應商中立(CNCF項目)。
Fluent Bit 從眾多日志源收集日志和指標,并將它們發(fā)送到不同的目的地。Fluent Bit 真正大放異彩的地方在于嵌入式、邊緣及其他資源受限的環(huán)境,因為精簡的運行時環(huán)境結(jié)合眾多的輸入/輸出選項至關重要。
4. Vector
Vector
是一款高性能的日志收集工具。與本文中的其他日志收集工具相比,這款產(chǎn)品比較新。
Vector 的主要優(yōu)勢:
● 高效的內(nèi)存/CPU消耗和高數(shù)據(jù)吞吐量。
● 良好的可靠性,正確性和交付方面有保證。
● 包括自定義 DSL,以一種安全、高性能的方式動態(tài)轉(zhuǎn)換數(shù)據(jù)。
● 支持基于指標和日志的有效負載。
● 大量的輸入和輸出集成。
● 可以部署為代理或聚合器。
由于廣泛的部署選項、同時支持指標和日志以及可用集成的數(shù)量,使 Vector 成為一種出色而靈活的選擇。由于 Vector 用 Rust 編寫,提供了內(nèi)存安全和效率保證,使其在其他現(xiàn)有工具中獨樹一幟。Vector 引入了單元測試框架,可以更輕松地維護復雜的日志收集工具拓撲。
此外,Vector 的軟件組件竭力為傳送到目的地的日志和事件提供交付保證。Vector 的用戶還可以獲得 Vector 組件的代碼總體穩(wěn)定性方面的保證。無論在新環(huán)境中還是在舊環(huán)境中工作,它都值得認真考慮。
結(jié) 語
很難判定哪一款工具主導市場,企業(yè)選擇合適的日志收集工具取決于其特定需求和要求。比如說,如果企業(yè)在為需要資源消耗少的物聯(lián)網(wǎng)應用程序?qū)ふ胰罩臼占ぞ?,那么最好使?Vector 或 Fluent Bit,而不是 Logstash。如果企業(yè)看重供應商的中立性,CNCF 支持的項目(比如 Fluentd 和 Fluent Bit)倒是不錯的選擇。仔細檢查性能、資源消耗、支持眾多輸入和輸出格式的靈活性、可擴展性、可靠性、供應商鎖定和安全要求,可以幫助企業(yè)找到適合的日志收集工具。
鏈接:https://cloud.tencent.com/developer/article/2203090?areaSource=102001.16&traceId=UcMPrQSQJHV9ushXsHVE0
-
數(shù)據(jù)
+關注
關注
8文章
7145瀏覽量
89583 -
開源
+關注
關注
3文章
3408瀏覽量
42713 -
Fluent
+關注
關注
0文章
25瀏覽量
11677
原文標題:Logstash、Fluentd、Fluent Bit 和 Vector,誰才是開源日志收集最強王者?
文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關推薦
魅族旗艦PRO 7對比vivo X9s評測:誰才是最強王者?
Elasticsearch+Fluentd+Kafka數(shù)據(jù)的采集流程講述
三星VS華為,誰是你心中的最強王者?
三星S8和OPPOR11哪個好?誰才是真正的拍照王者
基于DOCKER容器的ELK日志收集系統(tǒng)分析
![基于DOCKER容器的ELK<b class='flag-5'>日志</b><b class='flag-5'>收集</b>系統(tǒng)分析](https://file.elecfans.com/web2/M00/49/47/poYBAGKhwJmANuO2AAATOod54FM103.jpg)
華為Nova5Pro遇上華為P30Pro后,誰才是最強的華為旗艦呢?
Java日志框架中的王者是誰
Kubernetes如何在各個服務器上搜集日志后傳輸給Logstash
vivo大數(shù)據(jù)日志采集Agent設計實踐
分布式實時日志:ELK的部署架構(gòu)方案
統(tǒng)一日志數(shù)據(jù)流圖
![統(tǒng)一<b class='flag-5'>日志</b>數(shù)據(jù)流圖](https://file1.elecfans.com/web2/M00/04/93/wKgaombFj0aAGe4IAADwLIwKbPk973.png)
評論