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: false
for the Filestream inputclose_removed: false
for 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.
Note
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