偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Filebeat on k8s 日志采集實(shí)戰(zhàn)操作

大數(shù)據(jù) 數(shù)據(jù)分析
Filebeat? 提供了豐富的配置選項(xiàng),可以根據(jù)您的需求對(duì)日志數(shù)據(jù)進(jìn)行高度定制和篩選。它還支持自動(dòng)發(fā)現(xiàn)新容器、節(jié)點(diǎn)和服務(wù),并動(dòng)態(tài)調(diào)整采集策略。這使得它成為 Kubernetes 環(huán)境中日志采集的有力工具。

一、概述

Filebeat 是一個(gè)輕量級(jí)的開(kāi)源日志文件和數(shù)據(jù)收集器,由 Elastic 公司開(kāi)發(fā),用于采集、解析和發(fā)送日志數(shù)據(jù)。在 Kubernetes 中,F(xiàn)ilebeat通常用于采集容器日志,并將其發(fā)送到中央日志存儲(chǔ)、分析或搜索工具,如 Elasticsearch、Logstash 或 Fluentd。

以下是 Filebeat 在 Kubernetes 中日志采集的工作原理:

  1. Filebeat 容器部署:首先,在 Kubernetes 集群中創(chuàng)建一個(gè)或多個(gè) Filebeat 容器的 Pod。這些 Pod 可以位于同一節(jié)點(diǎn)上,也可以分布在多個(gè)節(jié)點(diǎn)上,具體取決于您的部署方式和需求。
  2. Filebeat 配置文件:每個(gè) Filebeat 容器需要一個(gè)配置文件,該文件定義了 Filebeat 要監(jiān)視的日志源、采集策略、日志過(guò)濾規(guī)則和目標(biāo)輸出等。配置文件通常以 YAML 格式定義。
  3. Kubernetes ConfigMap:Filebeat 配置文件通常存儲(chǔ)在 Kubernetes ConfigMap 中。ConfigMap 是 Kubernetes 中的資源,用于存儲(chǔ)配置數(shù)據(jù),以便它可以被多個(gè)容器訪問(wèn)。Filebeat 容器將掛載包含配置文件的 ConfigMap,并將其用作配置源。
  4. Filebeat 啟動(dòng):Filebeat 容器啟動(dòng)后,它會(huì)讀取配置文件并按照配置定義的規(guī)則開(kāi)始采集日志。這包括監(jiān)視容器的日志文件、容器日志目錄或其他數(shù)據(jù)源。
  5. 日志采集和解析:Filebeat 會(huì)定期掃描配置的日志源,并將新的日志行采集到內(nèi)部隊(duì)列中。它還可以對(duì)采集的日志進(jìn)行解析,以提取有用的信息,如時(shí)間戳、日志級(jí)別、標(biāo)簽等。Filebeat 可以根據(jù)您的配置對(duì)日志數(shù)據(jù)進(jìn)行結(jié)構(gòu)化處理。
  6. 輸出到目標(biāo):Filebeat 會(huì)將采集的日志數(shù)據(jù)發(fā)送到指定的輸出目標(biāo),通常是中央日志存儲(chǔ)、分析或搜索工具。常見(jiàn)的輸出目標(biāo)包括 Elasticsearch、Logstash、Kafka 或各種云日志服務(wù)。
  7. 數(shù)據(jù)傳輸和處理:輸出目標(biāo)將接收到的日志數(shù)據(jù)進(jìn)行存儲(chǔ)、處理、分析或可視化。這通常涉及到對(duì)數(shù)據(jù)的索引、搜索、過(guò)濾和可視化,以便用戶可以查詢和分析日志數(shù)據(jù)。

Filebeat 提供了豐富的配置選項(xiàng),可以根據(jù)您的需求對(duì)日志數(shù)據(jù)進(jìn)行高度定制和篩選。它還支持自動(dòng)發(fā)現(xiàn)新容器、節(jié)點(diǎn)和服務(wù),并動(dòng)態(tài)調(diào)整采集策略。這使得它成為 Kubernetes 環(huán)境中日志采集的有力工具。

總的來(lái)說(shuō),F(xiàn)ilebeat 的工作原理是不斷監(jiān)視和采集容器生成的日志,然后將這些日志數(shù)據(jù)發(fā)送到中央處理工具,以便分析和可視化。這有助于集中管理和分析容器日志,以便更好地了解應(yīng)用程序的狀態(tài)和性能。

圖片Filebeat 官方文檔:https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-overview.html

以前也寫過(guò)關(guān)于 filebeat 更詳細(xì)的介紹和實(shí)戰(zhàn)操作的文章,只不過(guò) filebeat 不是部署在 k8s 上,感興趣的小伙伴可以先查閱我之前的文章:

  • 輕量級(jí)的日志采集組件 Filebeat 講解與實(shí)戰(zhàn)操作
  • Filebeat 采集 k8s Pod 和 Events 日志實(shí)戰(zhàn)操作

二、K8s 集群部署

k8s 環(huán)境安裝之前寫過(guò)很多文檔,可以參考我以下幾篇文章:

  • 【云原生】k8s 離線部署講解和實(shí)戰(zhàn)操作
  • 【云原生】k8s 環(huán)境快速部署(一小時(shí)以內(nèi)部署完)

三、ElasticSearch 和 kibana 環(huán)境部署

這里可以選擇以下部署方式:

  • 通過(guò)docker-compose部署:通過(guò) docker-compose 快速部署 Elasticsearch 和 Kibana 保姆級(jí)教程
  • on k8s 部署:ElasticSearch+Kibana on K8s 講解與實(shí)戰(zhàn)操作(版本7.17.3)

這里我選擇 docker-compose 部署方式。

1)部署 docker

# 安裝yum-config-manager配置工具
yum -y install yum-utils

# 建議使用阿里云yum源:(推薦)
#yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

# 安裝docker-ce版本
yum install -y docker-ce
# 啟動(dòng)并開(kāi)機(jī)啟動(dòng)
systemctl enable --now docker
docker --version

2)部署 docker-compose

curl -SL https://github.com/docker/compose/releases/download/v2.16.0/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose

chmod +x /usr/local/bin/docker-compose
docker-compose --version

3)創(chuàng)建網(wǎng)絡(luò)

# 創(chuàng)建
docker network create bigdata

# 查看
docker network ls

4)修改 Linux 句柄數(shù)和最大線程數(shù)

#查看當(dāng)前最大句柄數(shù)
sysctl -a | grep vm.max_map_count
#修改句柄數(shù)
vi /etc/sysctl.conf
vm.max_map_count=262144

#臨時(shí)生效,修改后需要重啟才能生效,不想重啟可以設(shè)置臨時(shí)生效
sysctl -w vm.max_map_count=262144

#修改后需要重新登錄生效
vi /etc/security/limits.conf

# 添加以下內(nèi)容
* soft nofile 65535
* hard nofile 65535
* soft nproc 4096
* hard nproc 4096

# 重啟服務(wù),-h 立刻重啟,默認(rèn)間隔一段時(shí)間才會(huì)開(kāi)始重啟
reboot -h now

5)下載部署包開(kāi)始部署

# 這里選擇 docker-compose 部署方式
git clone https://gitee.com/hadoop-bigdata/docker-compose-es-kibana.git

cd docker-compose-es-kibana

chmod -R 777 es kibana

docker-compose -f docker-compose.yaml up -d

docker-compose ps

四、Filebeat on k8s 部署(daemonset)

部署包下載地址:https://artifacthub.io/packages/helm/elastic/filebeat

1)安裝 helm

# 下載包
wget https://get.helm.sh/helm-v3.9.4-linux-amd64.tar.gz
# 解壓壓縮包
tar -xf helm-v3.9.4-linux-amd64.tar.gz
# 制作軟連接
cp ./linux-amd64/helm /usr/local/bin/helm
# 驗(yàn)證
helm version
helm help

2)下載部署包進(jìn)行安裝

1、下載安裝包

helm repo add elastic https://helm.elastic.co

helm pull elastic/filebeat --version 7.17.3

tar -xf filebeat-7.17.3.tgz

2、修改配置

# 修改配置 filebeat/values.yaml,主要把 ELasticsearch 地址更換
vi filebeat/values.yaml

# 主要修改filebeat配置
  filebeatConfig:
    filebeat.yml: |
      filebeat.inputs:
      - type: container
        paths:
          - /var/log/containers/*.log
        fields:
          index: k8s-pod-log
        processors:
        - add_kubernetes_metadata:
            host: ${NODE_NAME}
            matchers:
            - logs_path:
                logs_path: "/var/log/containers/"

      output.elasticsearch:
        host: '${NODE_NAME}'
        hosts: '192.168.182.110:9200'
        index: "filebeat-%{[fields][index]}-%{+yyyy.MM.dd}"

      setup.template.name: "default@template"
      setup.template.pattern: "filebeat-k8s-*"
      setup.ilm.enabled: false

3、開(kāi)始安裝 filebeat

helm install filebeat ./filebeat -n logging --create-namespace

kubectl get pods -n logging

3)檢查數(shù)據(jù)是否正常采集到 ES

訪問(wèn) kibana:http://ip:5601/

1、Stack Management

圖片圖片

2、索引模式

圖片圖片

3、開(kāi)始創(chuàng)建索引模式

圖片圖片

4、Discover 查詢數(shù)據(jù)

圖片圖片

其實(shí)采集原理是非常簡(jiǎn)單的,就是通過(guò)掛載宿主機(jī)的容器日志目錄 /var/lib/docker/containers 到容器的 /var/lib/docker/containers。

圖片圖片

但是通過(guò)這種掛載宿主機(jī)容器目錄有個(gè)弊端,就是只能采集 pod 標(biāo)準(zhǔn)輸出的日志,其它日志是收集不到的,下篇文章將介紹另外兩種方式采集來(lái)解決這個(gè)問(wèn)題。

責(zé)任編輯:武曉燕 來(lái)源: 大數(shù)據(jù)與云原生技術(shù)分享
相關(guān)推薦

2024-02-01 09:48:17

2022-10-10 12:54:00

Flink運(yùn)維

2023-09-27 00:12:23

2023-02-27 07:40:00

2023-03-06 07:19:50

2023-09-06 08:12:04

k8s云原生

2023-03-03 07:54:21

2022-11-08 08:55:31

2023-03-07 07:56:37

Sqoopk8s底層

2022-10-14 07:42:50

LuceneHTTPWeb

2023-08-29 10:27:32

2022-07-26 00:00:05

QoSK8s日志

2022-11-06 21:31:11

云原生Sentinel集群模式

2022-04-22 13:32:01

K8s容器引擎架構(gòu)

2023-09-11 00:09:18

2023-03-01 07:42:12

HBase編排部署數(shù)據(jù)

2023-09-08 08:09:12

k8sservice服務(wù)

2023-11-06 07:16:22

WasmK8s模塊

2022-11-02 10:21:41

K8s pod運(yùn)維

2021-04-27 09:45:33

Nginx日志運(yùn)維
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)