Output Formats
Some of the output plugin's has a configuration field called formats
, with a limited amount of options are available (json
, json_stream
, json_lines
, msgpack
, gelf
).
The specifications, or reference to external documentation of the formats, is available in this page.
JSON formats
The most custom format options are the JSON types. The following are common variants of sending JSON encoded data over various APIs.
The following example payloads are modified for readability.
Records shown in example payloads are the three first commits of the Fluent Bit repository.
json
json
Queued records encoded as a single JSON array of JSON encoded Fluent Bit records.
Example payload
[
{
"timestamp": 1398282091.000,
"log": "Core: initialization and 32 bit fixes.",
"commit": "b327996bfcbc0f1f47e62c862c6f303592dfacea",
"author": "Eduardo Silva"
},
{
"timestamp": 1422350608.000,
"log": "Initial import.",
"commit": "49269c5ec3c74411943e362cfef85052665ae97f",
"author": "Eduardo Silva"
},
{
"timestamp": 1422418113.000,
"log": "Doc: add reference to Apache License v2.0",
"commit": "6e09478733e8273ec216328dfc921e622740695d",
"author": "Eduardo Silva"
}
]
json_stream
json_stream
a.k.a. Concatenated JSON
Queued JSON-encoded Fluent Bit records, with no separator between records.
Example json_stream
payload
json_stream
payload{
"timestamp": 1398282091.000,
"log": "Core: initialization and 32 bit fixes.",
"commit": "b327996bfcbc0f1f47e62c862c6f303592dfacea",
"author": "Eduardo Silva"
}{
"timestamp": 1422350608.000,
"log": "Initial import.",
"commit": "49269c5ec3c74411943e362cfef85052665ae97f",
"author": "Eduardo Silva"
}{
"timestamp": 1422418113.000,
"log": "Doc: add reference to Apache License v2.0",
"commit": "6e09478733e8273ec216328dfc921e622740695d",
"author": "Eduardo Silva"
}
json_lines
json_lines
Also known as newline-delimited JSON.
Queued JSON-encoded Fluent Bit records, separated by line-breaks (\n
).
Example json_lines
payload
json_lines
payload{
"timestamp": 1398282091.000,
"log": "Core: initialization and 32 bit fixes.",
"commit": "b327996bfcbc0f1f47e62c862c6f303592dfacea",
"author": "Eduardo Silva"
}
{
"timestamp": 1422350608.000,
"log": "Initial import.",
"commit": "49269c5ec3c74411943e362cfef85052665ae97f",
"author": "Eduardo Silva"
}
{
"timestamp": 1422418113.000,
"log": "Doc: add reference to Apache License v2.0",
"commit": "6e09478733e8273ec216328dfc921e622740695d",
"author": "Eduardo Silva"
}
msgpack
msgpack
MessagePack is a binary format for serializing objects.
Refer to the official MessagePack format specification.
GELF
Graylog Extended Log Format (GELF) is a JSON based log format which is designed to avoid the shortcomings of classic plain syslog.
See the official documentation for the GELF format.
It uses a fixed set of keys, with the addition of adding custom keys prefixed by one single underscore character.
Example GELF payload
Here is an example payload, copied directly from the official documentation.
{
"version": "1.1",
"host": "example.org",
"short_message": "A short message that helps you identify what is going on",
"full_message": "Backtrace here\n\nmore stuff",
"timestamp": 1385053862.3072,
"level": 1,
"_user_id": 9001,
"_some_info": "foo",
"_some_env_var": "bar"
}
Last updated
Was this helpful?