Files are not fully ingested when using autodiscover
Stack
By default Filebeat closes files as soon as they are removed. This can cause Filebeat not to ingest the last log lines if files are removed shortly after the last entries were written. This is a common cause of data loss when using Kubernetes autodiscover.
To prevent this from happening, set:
close.on_state_change.removed: falsefor the Filestream inputclose_removed: falsefor the Log or Container input.
Stack
Stack
The hints based autodiscover configuration includes the
close.on_state_change.removed setting, set to false by default.
In Filebeat versions 8.x and between versions 9.0.0 - 9.0.7 and 9.1.0 - 9.1.4, this setting isn't specified by default, so you must add it to the configuration manually.
Here is an example of setting close.on_state_change.removed: false
when using hints on Kubernetes:
filebeat.autodiscover:
providers:
- type: kubernetes
hints.enabled: true
hints.default_config:
type: filestream
id: container-logs-${data.container.id}
prospector.scanner.symlinks: true
close.on_state_change.removed: false
parsers:
- container: ~
paths:
- /var/log/containers/*-${data.container.id}.log