Filebeat多Input配置文件参考
Filebeat基础参考 (log到kafka,多配置文件参考)
input配置 filebeat.config.inputs 参考官网(https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-configuration-reloading.html)
官网:https://www.elastic.co/cn/beats/filebeat
多input配置示例(filebeat.config.inputs)
1、programs/filebeat/filebeat.yml 示例:
###################### Filebeat Configuration Example ######################### # This file is an example configuration file highlighting only the most common # options. The filebeat.reference.yml file from the same directory contains all the # supported options with more comments. You can use it as a reference. # # You can find the full configuration reference here: # https://www.elastic.co/guide/en/beats/filebeat/index.html # For more available modules and options, please see the filebeat.reference.yml sample # configuration file. #=========================== Filebeat inputs ============================= filebeat.registry.path: /home/pirate/var/filebeat/registry filebeat.modules: filebeat.config.inputs: enabled: true path: configs/*.yml reload.enabled: true reload.period: 10s filebeat.inputs: # Each - is an input. Most options can be set at the input level, so # you can use different inputs for various configurations. # Below are the input specific configurations. #exclude_lines: ['^DBG'] - type: log enabled: true paths: - /var/log # fields_under_root: true #exclude_lines: ['^DBG'] #exclude_lines: ['^DBG'] # Include lines. A list of regular expressions to match. It exports the lines that are # matching any regular expression from the list. #include_lines: ['^ERR', '^WARN'] # Exclude files. A list of regular expressions to match. Filebeat drops the files that # are matching any regular expression from the list. By default, no files are dropped. #exclude_files: ['.gz$'] # Optional additional fields. These fields can be freely picked # to add additional information to the crawled log files for filtering #fields: # level: debug # review: 1 ### Multiline options # Multiline can be used for log messages spanning multiple lines. This is common # for Java Stack Traces or C-Line Continuation # The regexp Pattern that has to be matched. The example pattern matches all lines starting with [ #multiline.pattern: ^\[ # Defines if the pattern set under pattern should be negated or not. Default is false. #multiline.negate: false # Match can be set to "after" or "before". It is used to define if lines should be append to a pattern # that was (not) matched before or after or as long as a pattern is not matched based on negate. # Note: After is the equivalent to previous and before is the equivalent to to next in Logstash #multiline.match: after #============================= Filebeat modules =============================== filebeat.config.modules: # Glob pattern for configuration loading path: ${path.config}/modules.d/*.yml # Set to true to enable config reloading reload.enabled: false # Period on which files under path should be checked for changes #reload.period: 10s #==================== Elasticsearch template setting ========================== setup.template.settings: index.number_of_shards: 1 #index.codec: best_compression #_source.enabled: false #================================ General ===================================== # The name of the shipper that publishes the network data. It can be used to group # all the transactions sent by a single shipper in the web interface. #name: # The tags of the shipper are included in their own field with each # transaction published. #tags: ["service-X", "web-tier"] # Optional fields that you can specify to add additional information to the # output. #fields: # env: staging #============================== Dashboards ===================================== # These settings control loading the sample dashboards to the Kibana index. Loading # the dashboards is disabled by default and can be enabled either by setting the # options here or by using the `setup` command. #setup.dashboards.enabled: false # The URL from where to download the dashboards archive. By default this URL # has a value which is computed based on the Beat name and version. For released # versions, this URL points to the dashboard archive on the artifacts.elastic.co # website. #setup.dashboards.url: #============================== Kibana ===================================== # Starting with Beats version 6.0.0, the dashboards are loaded via the Kibana API. # This requires a Kibana endpoint configuration. setup.kibana: # Kibana Host # Scheme and port can be left out and will be set to the default (http and 5601) # In case you specify and additional path, the scheme is required: http://localhost:5601/path # IPv6 addresses should always be defined as: https://[2001:db8::1]:5601 #host: "localhost:5601" # Kibana Space ID # ID of the Kibana Space into which the dashboards should be loaded. By default, # the Default Space will be used. #space.id: #============================= Elastic Cloud ================================== # These settings simplify using Filebeat with the Elastic Cloud (https://cloud.elastic.co/). # The cloud.id setting overwrites the `output.elasticsearch.hosts` and # `setup.kibana.host` options. # You can find the `cloud.id` in the Elastic Cloud web UI. #cloud.id: # The cloud.auth setting overwrites the `output.elasticsearch.username` and # `output.elasticsearch.password` settings. The format is `<user>:<pass>`. #cloud.auth: #================================ Outputs ===================================== # Configure what output to use when sending the data collected by the beat. output.kafka: enabled: true hosts: ["kafka0:9092","kafka1:9092","kafka2:9092"] # kafka集群配置 # topic: "test" topic: '%{[fields.topic]}' processors: - add_id: ~ - add_host_metadata: ~ - add_cloud_metadata: ~ - add_locale: ~ - drop_fields: #清理的字段 fields: ["host","log","input","agent","ecs","host","beat.version"] #-------------------------- Elasticsearch output ------------------------------ # Array of hosts to connect to. # Protocol - either `http` (default) or `https`. #protocol: "https" # Authentication credentials - either API key or username/password. #api_key: "id:api_key" #username: "elastic" #password: "changeme" #----------------------------- Logstash output -------------------------------- #output.logstash: # The Logstash hosts #hosts: ["localhost:5044"] # Optional SSL. By default is off. # List of root certificates for HTTPS server verifications #ssl.certificate_authorities: ["/etc/pki/root/ca.pem"] # Certificate for SSL client authentication #ssl.certificate: "/etc/pki/client/cert.pem" # Client Certificate Key #ssl.key: "/etc/pki/client/cert.key" #================================ Processors ===================================== # Configure processors to enhance or manipulate events generated by the beat. #================================ Logging ===================================== # Sets log level. The default log level is info. # Available log levels are: error, warning, info, debug #logging.level: debug # At debug level, you can selectively enable logging only for some components. # To enable all selectors use ["*"]. Examples of other selectors are "beat", # "publish", "service". #logging.selectors: ["*"] logging.level: info logging.to_files: true logging.files: path: /home/pirate/log/filebeat name: filebeat keepfiles: 7 permissions: 0644 #============================== X-Pack Monitoring =============================== # filebeat can export internal metrics to a central Elasticsearch monitoring # cluster. This requires xpack monitoring to be enabled in Elasticsearch. The # reporting is disabled by default. # Set to true to enable the monitoring reporter. #monitoring.enabled: false # Sets the UUID of the Elasticsearch cluster under which monitoring data for this # Filebeat instance will appear in the Stack Monitoring UI. If output.elasticsearch # is enabled, the UUID is derived from the Elasticsearch cluster referenced by output.elasticsearch. #monitoring.cluster_uuid: # Uncomment to send the metrics to Elasticsearch. Most settings from the # Elasticsearch output are accepted here as well. # Note that the settings should point to your Elasticsearch *monitoring* cluster. # Any setting that is not set is automatically inherited from the Elasticsearch # output configuration, so if you have the Elasticsearch output configured such # that it is pointing to your Elasticsearch monitoring cluster, you can simply # uncomment the following line. #monitoring.elasticsearch: #================================= Migration ================================== # This allows to enable 6.7 migration aliases #migration.6_to_7.enabled: true #================================ HTTP Endpoint ====================================== ## Each beat can expose internal metrics through a HTTP endpoint. For security ## reasons the endpoint is disabled by default. This feature is currently experimental. ## Stats can be access through http://localhost:5066/stats . For pretty JSON output ## append ?pretty to the URL. # ## Defines if the HTTP endpoint is enabled. http.enabled: true # ## The HTTP endpoint will bind to this hostname or IP address. It is recommended to use only localhost. http.host: localhost # ## Port on which the HTTP endpoint will bind. Default is 5066. http.port: 5066 #
2、programs/filebeat/inputs.d/test_filebeat.yml 文件示例
- type: log # Change to true to enable this input configuration. enabled: true # Paths that should be crawled and fetched. Glob based paths. paths: - /home/pirate/log/backend_log/gn/*/*/Flow.log fields: gn: 'test' project_id: 10 topic: test-flow # 文件日志,每十分更新一组,极限情况,可能个别的文件,间隔时间在10分钟 close_inactive: 11m #编码,默认无,plain(不验证或者改变任何输入), encoding: plain #更改时间超过7天的日志文件,不再处理 ignore_older: 168h #系统默认每间隔10s采集重现开始检查新文件 来监控新文件的内容变化情况 scan_frequency: 10s #单文件最大收集的字节数。默认10M max_bytes: 10485760 #启用此选项后,Filebeat会在指定的不活动时间段过后删除文件的状态。 如果文件已被Filebeat忽略(文件早于ignore_older),则只能删除状态。 clean_inactive: 336h
posted on 2021-02-08 14:46 RICH-ATONE 阅读(1204) 评论(0) 编辑 收藏 举报