Skip to content

Commit

Permalink
Fixing filebeat holding onto old file descriptors
Browse files Browse the repository at this point in the history
Under certain scenariosFilebeat may hold onto old
log file descriptors. There are various settings
on Filebeat to prevent this from happening. This
patch adds to the charm three key settings that
help prevent this issue:

- ignore_older
- clean_inactive

Fixing: [canonical#87](canonical#87)
  • Loading branch information
al3jandrosg committed Jul 18, 2024
1 parent a643b43 commit 69a9d9f
Show file tree
Hide file tree
Showing 5 changed files with 78 additions and 0 deletions.
17 changes: 17 additions & 0 deletions config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -49,3 +49,20 @@ options:
default: ""
description: |
A YAML list which will be injected to define additional prospectors/inputs.
ignore_older:
type: string
default: "0"
description: |
If this option is enabled, Filebeat ignores any files that were modified before the specified timespan.
Configuring ignore_older can be especially useful if you keep log files for a long time. The passed
values should be integers, e.g., "90", "3600", "600". The values are assumed to be in seconds
https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-input-log.html#filebeat-input-log-ignore-older"
clean_inactive:
type: string
default: "0"
description: |
When this option is enabled, Filebeat removes the state of a file after the specified period of inactivity has
elapsed. Bear in mind that if clean_inactive is enabled, it must be greater than ignore_older + scan_frequency to
make sure that no states are removed while a file is still being harvested. The passed values should be integers,
e.g., "90", "3600", "600". The values are assumed to be in seconds:
https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-input-log.html#filebeat-input-log-clean-inactive"
51 changes: 51 additions & 0 deletions reactive/filebeat.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
import base64
import os
import time
import re


FILEBEAT_CONFIG = '/etc/filebeat/filebeat.yml'
Expand Down Expand Up @@ -190,6 +191,56 @@ def check_filebeat_repo():
remove_state('filebeat.repo.changed')


@when('apt.installed.filebeat')
@when('config.changed')
def sanity_check():
config_items = {
'ignore_older': config().get('ignore_older'),
'clean_inactive': config().get('clean_inactive')
}

log("Executing sanity checks on config values.")

# sanity check config strings
for cfg, value in config_items.items():
if is_valid_time_string(value) is None:
log("Invalid config, the value for {} is not an integer."
"Passed value: {}.".format(cfg, value))
#status.blocked("Invalid config. Please check the logs for details.")
status_set("blocked", "Invalid config. Please check the logs for details.")
return

# sanity check value compliance (e.g., clean_inactive must be greater
# than ignore_older + scan_frequency). scan_frequency is no longer a
# charm config option but it defaults to 10s and it's set to that in
# the charm templates so using that below.
scan_frequency = 10
ignore_older = int(config_items['ignore_older'])
clean_inactive = int(config_items['clean_inactive'])

if clean_inactive and \
int(clean_inactive) <= int(ignore_older) + int(scan_frequency):
log("Invalid config, make sure that the value for 'clean_inactive' "
"is greater than 'ignore_older + scan_frequency'.")
#status.blocked("Invalid config. Please check the logs for details.")
status_set("blocked", "Invalid config. Please check the logs for details.")
return

log("Charm config sanity checks passed. Restarting Filebeat")
service("restart", "filebeat")


def is_valid_time_string(str_in):
"""
Returns str_in as integer if possible, logs an error and returns
None otherwise.
"""
try:
return int(str_in)
except (ValueError, TypeError):
return None


@hook('stop')
def remove_filebeat():
"""Stop, purge, and remove all traces of filebeat."""
Expand Down
4 changes: 4 additions & 0 deletions templates/filebeat-5.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ filebeat:
scan_frequency: 10s
harvester_buffer_size: {{ harvester_buffer_size }}
max_bytes: {{ max_bytes }}
ignore_older: {{ ignore_older }}
clean_inactive: {{ clean_inactive }}
fields:
juju_model_name: {{ juju_model_name }}
juju_model_uuid: {{ juju_model_uuid }}
Expand All @@ -34,6 +36,8 @@ filebeat:
scan_frequency: 10s
harvester_buffer_size: {{ harvester_buffer_size }}
max_bytes: {{ max_bytes }}
ignore_older: {{ ignore_older }}
clean_inactive: {{ clean_inactive }}
fields_under_root: true
symlinks: true
# NB: disable json decoding; setting any of these would result in the
Expand Down
4 changes: 4 additions & 0 deletions templates/filebeat-6.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ filebeat:
scan_frequency: 10s
harvester_buffer_size: {{ harvester_buffer_size }}
max_bytes: {{ max_bytes }}
ignore_older: {{ ignore_older }}
clean_inactive: {{ clean_inactive }}
fields_under_root: false
fields:
type: logpath-logs
Expand All @@ -39,6 +41,8 @@ filebeat:
scan_frequency: 10s
harvester_buffer_size: {{ harvester_buffer_size }}
max_bytes: {{ max_bytes }}
ignore_older: {{ ignore_older }}
clean_inactive: {{ clean_inactive }}
fields_under_root: false
fields:
type: container-logs
Expand Down
2 changes: 2 additions & 0 deletions templates/filebeat-7.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ filebeat:
scan_frequency: 10s
harvester_buffer_size: {{ harvester_buffer_size }}
max_bytes: {{ max_bytes }}
ignore_older: {{ ignore_older }}
clean_inactive: {{ clean_inactive }}
fields_under_root: false
fields:
type: logpath-logs
Expand Down

0 comments on commit 69a9d9f

Please sign in to comment.