002、配置filebeat实战案例
本文最后更新于 66 天前,其中的信息可能已经过时,如有错误请发送邮件到wuxianglongblog@163.com

配置filebeat实战案例

一.filebeat的输入源(input)配置案例

1.从标准输入读取数据

[root@elk101.oldboyedu.com ~/conf]# vim stdin-to-console.yaml 
[root@elk101.oldboyedu.com ~/conf]# 
[root@elk101.oldboyedu.com ~/conf]# cat stdin-to-console.yaml 
filebeat.inputs:
- type: stdin
  enabled: true

output.console:
  pretty: true
  enable: true
[root@elk101.oldboyedu.com ~/conf]# 
[root@elk101.oldboyedu.com ~/conf]# filebeat -e -c stdin-to-console.yaml 

2.从文件中读取数据

[root@elk101.oldboyedu.com ~/conf]# vim file-to-console.yaml 
[root@elk101.oldboyedu.com ~/conf]# 
[root@elk101.oldboyedu.com ~/conf]# cat file-to-console.yaml 
filebeat.inputs:
- type: log
  paths:
    - /oldboyedu/logs/linux77/*.log
  include_lines: ['oldboyedu']
  fields:
    school: oldboyedu
    class: linux77
    address: ["北京沙河","上海","深圳"]
  tags: ["oldboyedu-linux77","历史最优班级"] 

- type: log
  paths:
    - /oldboyedu/logs/linux77/linux77.txt 
  exclude_lines: ['^linux']
  fields:
    school: oldboyedu
    class: linux77
    address: ["北京沙河","上海","深圳"]
  fields_under_root: true
  tags: ["历史最优班级 oldboyedu linux77"]

output.console:
  pretty: true
[root@elk101.oldboyedu.com ~/conf]# 
[root@elk101.oldboyedu.com ~/conf]# filebeat -e -c file-to-console.yaml  

推荐阅读:
    https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-input-log.html

3.从tcp类型读取数据

vim 02-tcp-to-console.yml 
filebeat.inputs:
- type: tcp
  max_message_size: 10MiB
  host: "10.0.0.106:7777"
  timeout: 10

output.console:
  pretty: true
  bulk_max_size: 10MiB

推荐阅读:
    https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-input-tcp.html

4.从redis类型读取数据[从慢日志中读取,目前是测试阶段]

(1)启动redis
cat > /oldboyedu/softwares/redis/redis16379.conf << EOF
port 16379
daemonize yes
bind 10.0.0.108
requirepass "oldboyedu_linux77"
slowlog-max-len=1
slowlog-log-slower-than=1000
EOF
redis-server /oldboyedu/softwares/redis/redis16379.conf

(2)链接redis进行测试
redis-cli -h 10.0.0.108 -p 16379 -a oldboyedu_linux77

(3)编写filebeat的配置文件
filebeat.inputs:
- type: redis
  hosts: ["10.0.0.108:16379"]
  network: tcp4
  password: "oldboyedu_linux77"
  timeout: 3

output.console:
  pretty: true

温馨提示:   
    filebeat会从redis的慢日志中读取数据,但可能课上无法模拟出慢查询操作!等待完善....

推荐阅读:
    https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-input-redis.html

5.从kafka类型读取数据

(1)启动kafka集群
    略.

(2)创建topic
kafka-topics.sh --bootstrap-server 10.0.0.108:9092 --create --topic oldboyedu-linux77 --partitions 10 --replication-factor 3

(3)查看topic
kafka-topics.sh --bootstrap-server 10.0.0.108:9092 --list

(4)查看消费者组
kafka-consumer-groups.sh --bootstrap-server 10.0.0.108:9092 --list

(5)启动生产者
kafka-console-producer.sh --bootstrap-server 10.0.0.108:9092 --topic oldboyedu-linux77

(6)编写filebeat的配置文件并启动
filebeat.inputs:
- type: kafka
  hosts:
    - 10.0.0.108:9092
    - 10.0.0.107:9092
    - 10.0.0.106:9092
  topics: ["oldboyedu-linux77"]
  group_id: "oldboyedu-filebeat"

output.console:
  pretty: true

(7)再次查看消费者组
kafka-consumer-groups.sh --bootstrap-server 10.0.0.108:9092 --list

推荐阅读:
    https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-input-kafka.html

二.filebeat的输出源配置案例

1.将数据输出到kafka:star:

(1)启动kafka集群
    略.

(2)配置filebeat并启动
filebeat.inputs:
- type: tcp
  max_message_size: 10MiB
  host: "10.0.0.106:7777"

output.kafka:
  # 指定主机
  hosts: ["10.0.0.106:9092", "10.0.0.107:9092", "10.0.0.108:9092"]

  # 指定topic
  topic: 'oldboyedu_linux77_2021'

(3)启动消费者查看数据
kafka-console-consumer.sh --bootstrap-server 10.0.0.108:9092 --topic oldboyedu_linux77_2021 --from-beginning 

推荐阅读:
    https://www.elastic.co/guide/en/beats/filebeat/current/kafka-output.html

2.将数据输出到file

filebeat.inputs:
- type: tcp
  max_message_size: 10MiB
  host: "10.0.0.106:7777"

output.file:
  path: "/tmp/oldboyedu_linux77_filebeat"
  filename: linux77.log

推荐阅读:
    https://www.elastic.co/guide/en/beats/filebeat/current/file-output.html

3.将数据输出到redis

(1)编写配置文件并启动filebeat
filebeat.inputs:
- type: tcp
  max_message_size: 10MiB
  host: "10.0.0.106:7777"

output.redis:
  hosts: ["10.0.0.108:16379"]
  password: "oldboyedu_linux77"
  key: "oldboyedu-filebeat"
  db: 10
  timeout: 5

(2)查看数据的内容
redis-cli -h 10.0.0.108 -p 16379 -a oldboyedu_linux77 --raw -n 10 LRANGE oldboyedu-filebeat 0 -1

推荐阅读:
    https://www.elastic.co/guide/en/beats/filebeat/current/redis-output.html

4.输出到ES:star:

filebeat.inputs:
- type: tcp
  max_message_size: 10MiB
  host: "10.0.0.106:7777"

output.elasticsearch:
  hosts: 
    - "http://10.0.0.106:9200"
    - "http://10.0.0.107:9200"
    - "http://10.0.0.108:9200"

  index: "oldboyedu-linux77-filebeat-%{+yyyy.MM.dd}"

# 禁用索引生命周期并设置索引的模板!
setup.ilm.enabled: false
setup.template.name: "oldboyedu-linux77-filebeat"
setup.template.pattern: "oldboyedu-linux77-*"
setup.template.overwrite: true
setup.template.settings:
  index.number_of_shards: 10
  index.number_of_replicas: 0

推荐阅读:
    https://www.elastic.co/guide/en/beats/filebeat/current/elasticsearch-output.html
    https://www.elastic.co/guide/en/beats/filebeat/current/configuration-template.html
    https://www.elastic.co/guide/en/beats/filebeat/current/ilm.html

三.Filebeat Module的基本使用(了解即可)

1.查看默认的module

    前面要实现日志数据的读取以及处理都是自己手动设置的,是不是感觉是有点烦呀?

    其实,在filebeat中,有大量的Modele,可以简化我们的配置,直接就可以使用。

2.查看filebeat已启用和已经禁用的模块

[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# filebeat modules list 
    Enabled:
        已经启用的模块。

    Disabled:
        没有启用的模块。

温馨提示:
    可以看到,内置了很多的module,但是都没有启用,如果需要启用需要进行enable操作。

3.启用模块和禁用模块

    启用模块:
        [root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# filebeat modules enable nginx

    禁用模块:
        [root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# filebeat modules disable nginx

    温馨提示:
        如下图所示,启用或者禁用模块,会修改对应的配置文件后缀哟~

image-20210602213828457

4.配置nginx module文件

[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# egrep -v "^*#|^$" modules.d/nginx.yml 
- module: nginx
  access:
    enabled: true
  error:
    enabled: true
  ingress_controller:
    enabled: false
[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# 
[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# vim modules.d/nginx.yml 
[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# 
[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# egrep -v "^*#|^$" modules.d/nginx.yml 
- module: nginx
  access:
    enabled: true
    var.paths: ["/var/log/nginx/access.log*"]
  error:
    enabled: true
    var.paths: ["/var/log/nginx/error.log*"]
  ingress_controller:
    enabled: false
[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# 

温馨提示:
    (1)我们指定的"access.log*"和"error.log*",目的是通配所有的日志文件,生产环境中都会配置日志滚动;
    (2)关于启用module的使用也可以基于命令行的方式使用哟,只需启动的时候使用"-M"参数指定即
可;

推荐阅读:
    https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-module-nginx.html

5.配置filebeat实例并引用上面配置的模块

[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# vim module-to-es.yaml 
[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# 
[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# cat module-to-es.yaml 
# 指定filebeat的输入信息,我们不做任何配置,因为下面我们使用了modules。
filebeat.inputs:

# 指定filebeat输出类型
output.elasticsearch:
  hosts: ["elk101.oldboyedu.com:9200","elk102.oldboyedu.com:9200","elk103.oldboyedu.com:9200"]
  index: "oldboy-module-%{[agent.version]}-%{+yyyy.MM.dd}"

# 禁用索引的生命周期!
setup.ilm.enabled: false
# 指定索引模板的名称
setup.template.name: "oldboyedu"
# 指定索引模板的匹配模式
setup.template.pattern: "oldboy-module-*"
# 指定索引模板的分片信息
setup.template.settings:
  index.number_of_shards: 5
  index.number_of_replicas: 0

# 启用modules
filebeat.config.modules:
  path: ${path.config}/modules.d/*.yml
  reload.enabled: false
[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# 
[root@elk101.oldboyedu.com /oldboy/softwares/filebeat]# filebeat -e -c module-to-es.yaml 

温馨提示:
    注意哈,如果我们在执行filebeat时,若不存在module目录,则你会发现ES始终无法收到数据哟~

image-20210602222450170

四.可能会遇到的报错

1.Exiting: setup.template.name and setup.template.pattern have to be set

if index name is modified

报错原因:
    未设置模板名称("setup.template.name")和模板的匹配方式("setup.template.pattern")。

解决方案:
    setup.ilm.enabled: false
    setup.template.name: "syslog"
    setup.template.pattern: "syslog-*"

1634037136189

2.配置指定分片无效

报错原因:
    如下所示,配置的分片设置无效。
        setup.template.settings:
          index.number_of_shards: 5
          index.number_of_replicas: 1

解决方案1:
    检查是否有之前的索引模板未删除,如果未删除,则可用删除索引模板。然后重新启动索引。

解决方案2:
    检查是否有之前的索引模板未删除,如果未删除,则可用直接对该索引模板进行修改,从而达到我们的目的。

3.Exiting: data path already locked by another beat. Please make sure that multiple beats are not sharing the same data path (path.data).

报错原因:
    启动了多个beats组件监听了相同的路径。

解决方案:
    检查配置文件,是否该配置文件配置的路径是否被其他beat实例监听了。
谨此笔记,记录过往。凭君阅览,如能收益,莫大奢望。
暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇