首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
如何配置Filebeat的输入插件

如何配置Filebeat的输入插件

热心网友
42
转载
2026-05-05

配置 Filebeat 输入插件

如何配置Filebeat的输入插件

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

要让Filebeat高效地采集数据,第一步就是正确配置输入插件。这就像给数据采集器装上合适的“探头”,不同的数据源需要不同的探头。下面,咱们就来拆解一下配置的核心要点。

一 配置结构与通用字段

Filebeat的输入配置,其骨架非常清晰。所有输入定义都放在 filebeat.inputs 这个数组下面,你可以同时配置多个输入源,互不干扰。每个输入都以 - type: <类型> 开头,常见的类型包括 filestream(处理文件,目前最推荐)、log(旧版文件输入,已不推荐)、stdintcp 以及 container(专门处理容器日志)。

无论选择哪种类型,有几个通用字段是绝大多数场景下都会用到的:

  • enabled: 这个开关控制是否启用该输入,默认是开启的(true)。
  • tags: 可以给采集到的事件打上标签,方便后续筛选和分类,比如 [“prod”, “web”]。
  • fields: 用于添加自定义字段,这些字段默认会嵌套在事件的 fields 对象下。
  • fields_under_root: 如果设为 true,上面自定义的字段就会被提升到事件的顶级,和系统自带字段平起平坐,查询起来更方便。
  • processors: 这是事件处理链,可以在数据发送前进行加工,比如丢弃特定事件(drop_event)、删除字段(drop_fields)、重命名(rename)或转换类型(convert)等。

一个典型的配置骨架长这样:

filebeat.inputs:
- type: filestream
  paths:
    - /var/log/*.log
  fields:
    app: nginx
  fields_under_root: true
  tags: [“prod”, “web”]
  processors:
    - add_fields:
        fields:
          env: prod

二 常用输入类型与关键选项

选对输入类型,事情就成功了一半。下面看看几种主流的选择。

  • 文件类输入
    • 推荐 filestream:这是目前处理文件日志的首选,功能强大且性能好。其关键选项包括:
      • paths: 指定文件路径,支持 glob 模式。比如 /var/log/*.log 匹配单层目录,而 /data/**/*.log 则可以递归匹配所有子目录下的日志文件。
      • parsers: 内置了解析器,可以直接处理多行日志(multiline)、NDJSON格式(ndjson)和容器日志格式(container)。
      一个配置示例如下:
      filebeat.inputs:
      - type: filestream
        paths: [“/var/log/app/*.log”]
        parsers:
          - multiline:
              type: count
              count_lines: 3
          - ndjson:
              add_error_key: true
              overwrite_keys: true
              target: json_fields
      
    • 旧版 log:这个类型虽然还能用,但官方已不推荐,建议新项目直接使用 filestream
  • 标准输入与 TCP 输入
    • stdin:主要用于调试,或者从管道接收数据,配置极其简单。
      filebeat.inputs:
      - type: stdin
      
    • tcp:用于接收通过网络TCP协议发送过来的日志流,适合接收其他应用直接推送的日志。
      • 关键选项:host(监听地址和端口,如 0.0.0.0:9000)、max_message_size(单条消息最大尺寸,如 10MiB)。
      filebeat.inputs:
      - type: tcp
        host: “0.0.0.0:9000”
        max_message_size: 10MiB
      
  • 容器日志输入
    • container:专门为容器环境设计,能自动解析常见的容器日志格式,提取时间戳等信息。
      • 关键选项:paths,通常指向Docker或容器运行时存放日志的目录,例如 /data/docker/containers/*/*.log
      filebeat.inputs:
      - type: container
        paths: [“/data/docker/containers/*/*.log”]
      
  • 重要提示
    • 请注意,docker 这个输入类型从 7.2.0 版本起就已经被废弃了,现在统一使用 container 类型。

三 行过滤与 JSON 解析

数据采集进来,往往还需要“精加工”。行过滤和JSON解析就是两个最常用的工具。

  • 行过滤
    • include_lines: 只采集匹配指定正则表达式的行。比如只收集错误和警告日志:[‘^ERR’, ‘^WARN’]
    • exclude_lines: 排除匹配指定正则表达式的行。比如忽略调试日志:[‘^DBG’]
    • exclude_files: 直接忽略匹配正则表达式的整个文件。比如不处理压缩文件:[‘.gz$’]
    • 执行顺序:需要留意的是,如果同时设置了 include 和 exclude,Filebeat 会先执行 include_lines,再对匹配到的行执行 exclude_lines。
  • JSON 解析
    • 对于文件或容器日志中已经是JSON格式的 message 字段,可以将其自动解析成结构化的字段。关键选项有:
      • json.keys_under_root: 如果设为 true,解析出来的键会直接放到事件的顶级。
      • json.add_error_key: 解析失败时,会添加一个 error 字段记录问题。
      • json.overwrite_keys: 当解析出的键与事件原有的顶级字段(如 @timestamp)冲突时,是否覆盖原字段。
      • json.target: 将整个解析结果放入指定的字段下,而不是分散到顶级。
      一个将JSON日志解析到独立字段的示例如下:
      filebeat.inputs:
      - type: filestream
        paths: [“/var/log/app/*.json”]
        parsers:
          - ndjson:
              add_error_key: true
              overwrite_keys: true
              target: json_data
              json.keys_under_root: false
      

四 多行日志与容器场景

处理复杂日志格式是实际运维中的常见挑战,这里有两个典型场景的应对策略。

  • 多行日志
    • 像Ja va异常堆栈这种跨越多行的日志,需要合并成一个完整事件。使用 filestream.parsers.multiline 可以轻松搞定,常见策略有两种:
      • 按固定行数聚合:比如无论内容,总是将5行合并为一个事件。
        filebeat.inputs:
        - type: filestream
          paths: [“/var/log/app/stack.log”]
          parsers:
            - multiline:
                type: count
                count_lines: 5
        
      • 按正则模式合并:更智能的方式。例如,以下配置将以 “Caused by:” 开头的行视为一个新事件的开始,并将其之前的行合并。
        filebeat.inputs:
        - type: filestream
          paths: [“/var/log/app/stack.log”]
          parsers:
            - multiline:
                pattern: ‘^Caused by:’
                negate: true
                match: after
        
  • 容器日志
    • 直接使用 container 输入类型,并指定到容器日志的存储路径(例如 /data/docker/containers/*/*.log)即可。Filebeat 会自动识别常见的日志格式,并提取出有效的时间戳等信息。
    • 如果之前在使用旧的 docker 类型,建议尽快迁移到 container 类型。

五 调试与运行

配置写好了,怎么验证它是否按预期工作呢?这里有几个快速验证和调试的方法。

  • 快速验证
    • 控制台输出:在配置文件中将输出设置为控制台,并美化格式,可以直观地看到采集到的事件结构。
      output.console:
        pretty: true
      
    • 启动命令
      • 前台调试模式启动:filebeat -e -c filebeat.yml
      • 指定自定义配置文件目录启动:filebeat -e -c config/your.yaml
  • 运行示例
    • TCP 输入测试
      1. 启动配置了 type: tcp, host: “0.0.0.0:9000” 的 Filebeat。
      2. 另开一个终端,发送测试数据:echo ‘hello filebeat’ | nc 127.0.0.1 9000
      3. 观察 Filebeat 控制台的输出,应该能看到接收到的事件。
    • 文件输入测试
      1. 启动配置了 type: filestream, paths: [“/tmp/test/*.log”] 的 Filebeat。
      2. 向目标文件写入日志:echo ‘{“level”:“info”,“msg”:“start”}’ > /tmp/test/a.log
      3. 观察 Filebeat 控制台,确认日志被正确采集并解析。
来源:https://www.yisu.com/ask/14951874.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

C++在Linux环境下如何进行网络通信
编程语言
C++在Linux环境下如何进行网络通信

Linux环境下C++网络通信:深入解析Socket套接字编程 套接字(Socket)是网络通信的核心端点,它构建了不同计算机间程序数据交换的桥梁。在Linux操作系统中,使用C++实现网络通信主要依赖于Socket编程这套标准化接口。掌握其原理与步骤,是开发高性能网络应用的基础。 本文将详细拆解L

热心网友
05.05
Linux C++中如何实现高效的排序算法
编程语言
Linux C++中如何实现高效的排序算法

在Linux环境下使用C++实现高效的排序算法 在Linux平台上用C++做开发,排序是绕不开的基础操作。如何实现高效排序?其实路子不少,关键得看场景。下面就来聊聊几种常用的策略和具体实现,从开箱即用的标准库到手动打造的高性能算法,咱们逐一拆解。 1 首选利器:标准库的高效排序函数 绝大多数情况下

热心网友
05.05
Linux下C++怎样使用容器技术
编程语言
Linux下C++怎样使用容器技术

Linux下C++容器技术使用指南 一 环境准备与编译运行 要在Linux系统上高效开发基于C++标准模板库(STL)的程序,首要任务是完成开发环境的配置。这一过程的核心在于安装合适的编译器和构建管理工具。其中,GCC G++编译器与CMake构建系统的组合是业界公认的经典方案。 以下是一组可直接执

热心网友
05.05
C++ Linux平台如何管理依赖
编程语言
C++ Linux平台如何管理依赖

C++ Linux 平台依赖管理实战指南 一 常用方式与适用场景 在Linux上管理C++依赖,方法不少,各有各的“脾气”和适用场景。选对了,事半功倍;选错了,可能就是一场与编译错误的持久战。 系统级包管理器:这是最“接地气”的方式。在 Debian Ubuntu 系列,你会用 apt 安装像 li

热心网友
05.05
Linux C++怎样使用网络库
编程语言
Linux C++怎样使用网络库

Linux C++网络编程:从基础Socket到现代库的实战指南 想在Linux环境下用C++玩转网络编程?那你来对地方了。这片天地里,从最底层的系统调用到封装完善的高层库,选择其实相当丰富。今天,我们就来聊聊几个最常用、也最值得掌握的网络库,看看它们各自怎么用,又适合哪些场景。 1 Socket

热心网友
05.05

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

红米Note11 Pro更新系统需连WiFi吗?
电脑教程
红米Note11 Pro更新系统需连WiFi吗?

红米Note 11 Pro系统升级,为何坚持要求连接Wi-Fi? 当红米Note 11 Pro收到MIUI或澎湃OS的系统更新推送时,官方总会明确提示:整个过程请在Wi-Fi网络环境下完成。这项要求并非随意设定,而是基于清晰的技术与体验考量。一次完整的系统升级包,其大小通常在2GB至4GB之间。如果

热心网友
05.05
小米13ultra有nfc功能吗
电脑教程
小米13ultra有nfc功能吗

小米13 Ultra的NFC功能深度解析:它如何重新定义“全场景智能交互”? 在旗舰手机领域,NFC功能看似已成为标配,但体验却千差万别。小米13 Ultra所搭载的全功能NFC方案,在“全能”与“好用”两个维度上树立了新的标杆。它不仅无缝集成了公交卡模拟、门禁卡复制、数字车钥匙等核心生活服务,更全

热心网友
05.05
嵌入式消毒柜电源插座位置必须外露吗?
电脑教程
嵌入式消毒柜电源插座位置必须外露吗?

嵌入式消毒柜电源插座安装指南:隐蔽式布局提升安全与美观 在规划嵌入式消毒柜的安装方案时,电源插座的布局方式直接影响到最终的整体效果与安全性。正确的做法是避免插座外露,采用隐蔽式安装。根据国家《住宅厨房设计规范》及主流厨电品牌的安装标准,推荐将插座预留在消毒柜后方或侧方的墙体内部,安装高度宜控制在距地

热心网友
05.05
魔音耳机操作说明包含充电指示吗?
电脑教程
魔音耳机操作说明包含充电指示吗?

是的,魔音(Beats)耳机充电状态一目了然,指示灯明确显示 当你为Beats头戴式耳机充电时,如何判断它是否已经充满?答案就藏在机身自带的五段式LED电量指示灯里。在充电过程中,这排指示灯会持续闪烁,实时反馈充电进度。一旦所有五个指示灯全部转为稳定常亮、不再闪烁,即代表电池已完全充满。整个充电周期

热心网友
05.05
博朗剃须刀如何识别型号?
电脑教程
博朗剃须刀如何识别型号?

博朗剃须刀型号全解析:从编码规则到选购技巧的终极指南 面对博朗剃须刀复杂的字母数字组合感到困惑?实际上,其型号命名体系逻辑严谨,是用户选购的核心依据。简单来说,型号首位的数字(1、3、5、7、9)直接代表产品系列,数字越大,通常意味着技术越先进、功能越全面、定位越高端。例如,顶级的9系旗舰机型普遍搭

热心网友
05.05