Systemd

The Systemd input plugin lets you collect log messages from the journald daemon in Linux environments.

Configuration parameters

The plugin supports the following configuration parameters:

Key
Description
Default

Path

Optional path to the Systemd journal directory. If not set, the plugin uses default paths to read local-only logs.

none

Max_Fields

Set a maximum number of fields (keys) allowed per record.

8000

Max_Entries

When Fluent Bit starts, the Journal might have a high number of logs in the queue. To avoid delays and reduce memory usage, use this option to specify the maximum number of log entries that can be processed per round. Once the limit is reached, Fluent Bit will continue processing the remaining log entries once journald performs the notification.

5000

Systemd_Filter

Perform a query over logs that contain specific journald key/value pairs. For example, _SYSTEMD_UNIT=UNIT. The Systemd_Filter option can be specified multiple times in the input section to apply multiple filters.

none

Systemd_Filter_Type

Define the filter type when Systemd_Filter is specified multiple times. Allowed values:And, Or. With And a record is matched only when all of the Systemd_Filter have a match. With Or a record is matched when any Systemd_Filter has a match.

Or

Tag

The tag is used to route messages but on Systemd plugin there is an additional capability: if the tag includes a wildcard (*), it will be expanded with the Systemd Unit file (_SYSTEMD_UNIT, like host.\* => host.UNIT_NAME) or unknown (host.unknown) if _SYSTEMD_UNIT is missing.

none

DB

Specify the absolute path of a database file to keep track of the journald cursor.

none

DB.Sync

Set a default synchronization (I/O) method. Values: Extra, Full, Normal, and Off. This flag affects how the internal SQLite engine synchronizes to disk. For more details SQL lite documentation. Available in Fluent Bit v1.4.6 and later.

Full

Read_From_Tail

Start reading new entries. Skip entries already stored injournald.

Off

Lowercase

Lowercase the journald field (key).

Off

Strip_Underscores

Remove the leading underscore of the journald field (key). For example, the journald field _PID becomes the key PID.

Off

Threaded

Indicates whether to run this input in its own thread.

false

Get started

To receive Systemd messages, you can run the plugin from the command line or through the configuration file.

Command line

From the command line you can let Fluent Bit listen for Systemd messages with the following options:

$ fluent-bit -i systemd \
             -p systemd_filter=_SYSTEMD_UNIT=docker.service \
             -p tag='host.*' -o stdout

This example collects all messages coming from the Docker service.

Configuration file

In your main configuration file append the following sections:

service:
    flush: 1
    log_level: info
    parsers_file: parsers.yaml

pipeline:
    inputs:
        - name: systemd
          tag: host.*
          systemd_filter: _SYSTEMD_UNIT=docker.service
    outputs:
        - name: stdout
          match: '*'

Last updated

Was this helpful?