Skip to content

ydb-platform/fluent-bit-ydb

Repository files navigation

fluent-bit-ydb - Fluent Bit output for YDB.

License Release PkgGoDev tests lint Go Report Card codecov Code lines Telegram WebSite PRs Welcome

Build

Build prerequisites:

  • Golang v1.21 or later
  • C compiler and linker suitable for the operating system used (needed to build the plugin's shared library)
  • make utility

To build the plugin, run the following command:

BIN=out_ydb.so make build

Configuration

The plugin supports the following configuration settings:

Parameter Description
ConnectionURL YDB connection URL, including the protocol, endpoint and database path (see the documentation)
TablePath Relative table path, may include the schema in form SchemaName/TableName
Columns JSON structure mapping the fields of FluentBit record to the columns of target YDB table. May include the pseudo-fields listed below
CredentialsAnonymous Configure as 1 for anonymous YDB authentication
CredentialsYcServiceAccountKeyFile Set to the path of file containing the service account (SA) key, to use the SA key YDB authentication
CredentialsYcServiceAccountKeyJson Set to the JSON data of the service account (SA) key instead of the filename (useful in K8s environment)
CredentialsYcMetadata Configure as 1 for virtual machine metadata YDB authentication
CredentialsStatic Username and password for YDB authentication, specified in the following format: username:password@
CredentialsToken Custom token value, to use the token authentication YDB mode
Certificates Path to the certificate authority (CA) trusted certificates file, or the literal trusted CA certificate value
LogLevel Plugin specific logging level, should be one of disabled, trace, debug, info, warn, error, fatal or panic (info is the default)

The following pseudo-fields are available, in addition to those available in the FluentBit record, to be mapped into the YDB table columns:

  • .timestamp - record's timestamp, mandatory
  • .input - record's input stream name, mandatory
  • .hash - uint64 hash value computed over all the data fields (except the pseudo-fields), optional
  • .other - the JSON document containing all the data fields which were not explicitly mapped to a field in the table, optional

Usage example

YDB database should be available, either in the form of a local single-node setup (see the Quickstart section in YDB Documentation), a fully managed service, or as part of the YDB cluster installed on self-hosted resources.

FluentBit should be installed, either version 2 or 3.

In the examples directory the following files are provided:

  • tail2ydb.sql - example of YDB table structure to capture the log;
  • tail2ydb.conf - example of FluentBit configuration to read from /var/log/syslog and write to YDB table;
  • docker-compose.yml - Docker Compose setup to run the single-node YDB instance for development or testing purposes.

Target table should be created in the YDB database prior to running FluentBit with the configuraton referencing it.

To run the example configuration, customize the YDB connection settings in the tail2ydb.conf file, and run the following command:

fluent-bit -e out_ydb.so -c examples/tail2ydb.conf