您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關如何使用fluentd來收集容器的日志,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
前面的 ELK 中我們是用 Filebeat 收集 Docker 容器的日志,利用的是 Docker 默認的 logging driver json-file
,我們將使用 fluentd
來收集容器的日志。
Fluentd 是一個開源的數據收集器,它目前有超過 500 種的 plugin,可以連接各種數據源和數據輸出組件。在接下來的實踐中,Fluentd 會負責收集容器日志,然后發送給 Elasticsearch。日志處理流程如下:
這里我們用 Filebeat 將 Fluentd 收集到的日志轉發給 Elasticsearch。這當然不是唯一的方案,Fluentd 有一個 plugin fluent-plugin-elasticsearch
可以直接將日志發送給 Elasticsearch。條條道路通羅馬,開源世界給予了我們多種可能性,可以根據需要選擇合適的方案。
同樣的,最高效的實踐方式是運行一個 fluentd 容器。
docker run -d -p 24224:24224 -p 24224:24224/udp -v /data:/fluentd/log fluent/fluentd
fluentd 會在 TCP/UDP 端口 24224 上接收日志數據,日志將保存在 Host 的 /data
目錄中。
編輯 Filebeat 的配置文件 /etc/filebeat/filebeat.yml
,將 /data
添加到監控路徑中。
重啟 Filebeat。
systemctl restart filebeat.service
啟動測試容器。
docker run -d \
--log-driver=fluentd \
--log-opt fluentd-address=localhost:24224 \
--log-opt tag="log-test-container-A" \
busybox sh -c 'while true; do echo "This is a log message from container A"; sleep 10; done;'
docker run -d \
--log-driver=fluentd \
--log-opt fluentd-address=localhost:24224 \
--log-opt tag="log-test-container-B" \
busybox sh -c 'while true; do echo "This is a log message from container B"; sleep 10; done;'
--log-driver=fluentd
告訴 Docker 使用 Fluentd 的 logging driver。
--log-opt fluentd-address=localhost:24224
將容器日志發送到 Fluentd 的數據接收端口。
--log-opt tag="log-test-container-A"
和 --log-opt tag="log-test-container-B"
在日志中添加一個可選的 tag,用于區分不同的容器。
容器啟動后,Kibana 很快就能夠查詢到容器的日志。
關于如何使用fluentd來收集容器的日志就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。