-
Notifications
You must be signed in to change notification settings - Fork 7
/
fluentbit.conf
112 lines (98 loc) · 2.64 KB
/
fluentbit.conf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
# The contents of this file are largely the same as the upstream
# https://github.com/GSA-TTS/cg-logshipper/blob/main/fluentbit.conf
# We decided to maintain our own version, with the addition of the
# Heartbeat, so that we can visually see in the logs that fluentbit is
# connection successfully to new relic. Any changes to this file will be for
# custom configuration purposes, directly related to the fac, and should not be
# used as the main .conf file, as that is located in the upstream cg-logshipper repo
[SERVICE]
flush 1
log_level debug
parsers_file parsers.conf
parsers_file /home/vcap/deps/0/apt/etc/fluent-bit/parsers.conf
plugins_File plugins.conf
[INPUT]
name dummy
dummy {"message":"Fluent Bit - Heartbeat"}
interval_sec 60
[INPUT]
name tcp
port 8888
format none
# Ship to s3:
[OUTPUT]
Name s3
Match *
bucket ${BUCKET_NAME}
region ${AWS_DEFAULT_REGION}
json_date_key time
json_date_format iso8601
store_dir /tmp/fluent-bit/s3
total_file_size 50M
upload_timeout 10m
# TODO: modify s3_key_format -- by app?
s3_key_format /fluent-bit-logs/%Y/%m/%d/%H/%M/%S
retry_limit 5
# TODO: do we care about data ordering?
preserve_data_ordering On
# Ship to New Relic:
[OUTPUT]
Name newrelic
Match *
licenseKey ${NEW_RELIC_LICENSE_KEY}
endpoint ${NEW_RELIC_LOGS_ENDPOINT}
# Uncomment to see the parsed messages in the logshipper's logs:
[OUTPUT]
name stdout
match *
### Filters run in order of appearance ###
# Initial pass at parsing the body of the request.
[FILTER]
name parser
match tcp.*
key_name log
parser post-with-syslog
reserve_data On
preserve_key On
[FILTER]
name modify
match tcp.*
Rename log raw_message
# Further filter of the already-extracted fields
[FILTER]
name parser
match tcp.*
key_name message
parser extract-gauge
reserve_data On
preserve_key On
# And so on ... (multiple passes let us capture fields in varying order)
[FILTER]
name parser
match tcp.*
key_name message
parser extract-tags
reserve_data On
preserve_key On
[FILTER]
name parser
match tcp.*
key_name message
parser extract-remainder
reserve_data On
preserve_key Off
# TODO: does this do anything?
[FILTER]
name parser
match tcp.*
key_name message
parser extract-json-object-from-message
reserve_data On
preserve_key On
# Process selected keys (tags, gauge) into (stringified) JSON
[FILTER]
name lua
match tcp.*
time_as_table On
script scripts/parse_keys_with_eq_pairs.lua
call parse_keys_with_eq_pairs