zoukankan      html  css  js  c++  java
  • 部署 Fluent Bit ( td-agent-bit )

    部署 Fluent Bit ( td-agent-bit )

    此处使用 yum 安装,如需要离线安装,可以参考离线安装dokcer的方式进行部署

    安装

    参考官方文档:https://docs.fluentbit.io/manual/installation/linux/redhat-centos

    • 配置yum仓库
    # cat >/etc/yum.repos.d/tb-aget-bit.repo<<EOF
    [td-agent-bit]
    name = TD Agent Bit
    baseurl = https://packages.fluentbit.io/centos/7/$basearch/
    gpgcheck=1
    gpgkey=https://packages.fluentbit.io/fluentbit.key
    enabled=1
    EOF
    
    • 安装
    # yum install td-agent-bit
    

    配置 Fluent Bit

    参考官档:
    https://docs.fluentbit.io/manual/administration/configuring-fluent-bit/configuration-file#config_include_file
    https://docs.fluentbit.io/manual/pipeline/inputs/systemd
    https://docs.fluentbit.io/manual/pipeline/outputs/elasticsearch

    # cd /etc/td-agent-bit/
    # vim evescn.conf
    
    [INPUT]
        Name         systemd
        Tag          test_evescn.*
        Systemd_Filter  _SYSTEMD_UNIT=evescn.service
    
    [OUTPUT]
        Name  es
        Match test_evescn.*
        Host  ES_IP
        Port  9200
        HTTP_User XXXXXXX (es-xpack的账户密码信息)
        HTTP_Passwd XXXXXXXXXXXXXXXXX (es-xpack的账户密码信息)
        Index test_evescn_index_228
        Type  test_evescn_type_228
        Logstash_format true
        Logstash_Prefix test_evescn
        Logstash_DateFormat %Y-%m-%d
    
    ## 编辑主配置文件,追加引入子配置文件 ```evescn.conf```
    # vim td-agent-bit.conf
    
    @INCLUDE evescn.conf
    

    启动 Fluent Bit

    systemctl start td-agent-bit
    systemctl enable td-agent-bit
    

    最后在 kibana 上面添加索引 test_evescn


    手动验证是否可用将日志推送到es

    在td-agent-bit服务器上面进行手动推送
    # /opt/td-agent-bit/bin/td-agent-bit -i  systemd
    	-p systemd_filter=_SYSTEMD_UNIT=evescn.service 
    	-p tag='test_evescn.*' 
    	-o es://ES_IP:9200/test_evescn_index_228/test_evescn_type_228 
    	-m '*'
    
    在es服务器上面验证是否有索引
    
    # curl -u 'XXXX:XXXXXXXXX' 'localhost:9200/_cat/indices?v'
    health status index                     uuid                   pri rep docs.count docs.deleted store.size pri.store.size
    green  open   test_evescn               q0t4O-GeTOSzio49mQ8B2A   1   0    1257047            0    628.9mb        628.9mb
    

    java日志格式非完全 json 如何转换?

    • 首先添加日志过滤规则
    # cat parsers.conf
    [PARSER]
        Name   evescn_parsers
        Format regex
        Regex ^(?<log_time>[^[]*)[(?<log_url>[^]]*)][(?<log_level>[^ ]*)][(?<log_tid>[^ ]*)]:(?<log_data>[^ ].*)
    
    • 测试网站

    https://rubular.com/r/X7BH0M4Ivm

    # 测试日志
    2021-01-26 05:48:58.626[com.tencent.nhccovid_19.service.GovDataServiceImpl->findAntibodyDetection#203][INFO][%PARSER_ERROR[tid]]:{"message":"查询失败","time":"0","url":"/evescn","urlName":"测试接口","userInfo":{"name":"evescn","id":"5100daxuuGxaad7433"}}
    

    • 配置文件中影响添加的规则
    # vim evescn.conf
    
    [INPUT]
        Name         systemd
        Tag          test_evescn.*
        Systemd_Filter  _SYSTEMD_UNIT=evescn.service
    
    [FILTER]
        Name parser
        Match test_evescn.*
        Key_Name log
        Parser evescn_parsers
        Reserve_Data On
        Preserve_Key On
    
    [FILTER]
        Name parser
        Match test_evescn.*
        Key_Name log_data
        Parser json
        Reserve_Data On
        Preserve_Key On
    
    [OUTPUT]
        Name  es
        Match test_evescn.*
        Host  ES_IP
        Port  9200
        HTTP_User XXXXXXX (es-xpack的账户密码信息)
        HTTP_Passwd XXXXXXXXXXXXXXXXX (es-xpack的账户密码信息)
        Index test_evescn_index_228
        Type  test_evescn_type_228
        Logstash_format true
        Logstash_Prefix test_evescn
        Logstash_DateFormat %Y-%m-%d
    
  • 相关阅读:
    @FeignClient同一个name使用多个配置类报错,解决方案【转+改进】
    spring cloud 与spring boot 版本不匹配引发的问题总结
    无聊系列
    基于redis+lua实现的分布式限流
    elasticsearch 优化笔记
    redis+lua库存扣减和冲正
    es-dsl笔记
    wiki—-Confluence搭建
    Linux常用命令
    SQLSERVER|CDC 日志变更捕获机制
  • 原文地址:https://www.cnblogs.com/evescn/p/14330490.html
Copyright © 2011-2022 走看看