You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
@@ -12,28 +12,27 @@ operational Elasticsearch service running in your environment.
12
12
13
13
| Key | Description | Default |
14
14
| :--- | :--- | :--- |
15
-
|`Host`| IP address or hostname of the target Elasticsearch instance | 127.0.0.1 |
15
+
|`Host`| IP address or hostname of the target Elasticsearch instance |`127.0.0.1`|
16
16
|`Port`| TCP port of the target Elasticsearch instance | 9200 |
17
-
|`Path`| Elasticsearch accepts new data on HTTP query path `/_bulk`. It's also possible to serve Elasticsearch behind a reverse proxy on a sub-path. Define the path by adding a path prefix in the indexing HTTP POST URI. | Empty string |
18
-
|`compress`| Set payload compression mechanism. Option available is 'gzip' ||
19
-
|`Buffer_Size`| Specify the buffer size used to read the response from the Elasticsearch HTTP service. Useful for debugging purposes where it's required to read full responses. Response size grows depending of the number of records inserted. To set an _unlimited_ amount of memory set this value to **False**, otherwise the value must be according to the [Unit Size](../../administration/configuring-fluent-bit/unit-sizes.md) specification. |`512KB`|
20
-
|`Pipeline`|Newer versions of Elasticsearch allows to setup filters called pipelines. This option allows to define which pipeline the database should use. For performance reasons is strongly suggested to do parsing and filtering on Fluent Bit side, avoid pipelines. ||
21
-
|`AWS_Auth`| Enable AWS Sigv4 Authentication for Amazon OpenSearch Service | Off |
22
-
|`AWS_Region`| Specify the AWS region for Amazon OpenSearch Service ||
17
+
|`Path`| Elasticsearch accepts new data on HTTP query path `/_bulk`. You can also serve Elasticsearch behind a reverse proxy on a sub-path. Define the path by adding a path prefix in the indexing HTTP POST URI. | Empty string |
18
+
|`compress`| Set payload compression mechanism. Option available is `gzip`. ||
19
+
|`Buffer_Size`| Specify the buffer size used to read the response from the Elasticsearch HTTP service. Use for debugging purposes where required to read full responses. Response size grows depending of the number of records inserted. To use an unlimited amount of memory, set this value to `False`. Otherwise set the value according to the [Unit Size](../../administration/configuring-fluent-bit/unit-sizes.md). |`512KB`|
20
+
|`Pipeline`|Define which pipeline the database should use. For performance reasons, it's strongly suggested to do parsing and filtering on Fluent Bit side, and avoid pipelines. ||
21
+
|`AWS_Auth`| Enable AWS Sigv4 Authentication for Amazon OpenSearch Service.|`Off`|
22
+
|`AWS_Region`| Specify the AWS region for Amazon OpenSearch Service.||
23
23
|`AWS_STS_Endpoint`| Specify the custom STS endpoint to be used with STS API for Amazon OpenSearch Service ||
24
24
|`AWS_Role_ARN`| AWS IAM Role to assume to put records to your Amazon cluster ||
25
25
|`AWS_External_ID`| External ID for the AWS IAM Role specified with `aws_role_arn`||
26
26
|`AWS_Service_Name`| Service name to use in AWS Sigv4 signature. For integration with Amazon OpenSearch Serverless, set to `aoss`. See the [FAQ](opensearch.md#faq) section on Amazon OpenSearch Serverless for more information. |`es`|
27
27
|`AWS_Profile`| AWS profile name | default |
28
-
| `Cloud_ID` | If using Elastic's Elasticsearch Service you can specify the `cloud_id` of the cluster running. The string has the format `<deployment_name>:<base64_info>`. Once decoded, the `base64_info` string has the format `<deployment_region>$<elasticsearch_hostname>$<kibana_hostname>`.
29
-
||
28
+
|`Cloud_ID`| If using Elastic's Elasticsearch Service you can specify the `cloud_id` of the cluster running. The string has the format `<deployment_name>:<base64_info>`. Once decoded, the `base64_info` string has the format `<deployment_region>$<elasticsearch_hostname>$<kibana_hostname>`. ||
30
29
|`Cloud_Auth`| Specify the credentials to use to connect to Elastic's Elasticsearch Service running on Elastic Cloud ||
31
30
|`HTTP_User`| Optional username credential for Elastic X-Pack access ||
32
31
|`HTTP_Passwd`| Password for user defined in `HTTP_User`||
33
-
|`Index`| Index name | fluent-bit |
32
+
|`Index`| Index name |`fluent-bit`|
34
33
|`Type`| Type name |`_doc`|
35
34
|`Logstash_Format`| Enable Logstash format compatibility. This option takes a Boolean value: `True/False`, `On/Off`|`Off`|
36
-
|`Logstash_Prefix`| When Logstash\_Format is enabled, the Index name is composed using a prefix and the date, e.g: If `Logstash_Prefix` is equal to `mydata` your index will become `mydata-YYYY.MM.DD`. The last string appended belongs to the date when the data is being generated. |`logstash`|
35
+
|`Logstash_Prefix`| When `Logstash_Format` is enabled, the Index name is composed using a prefix and the date, e.g: If `Logstash_Prefix` is equal to `mydata` your index will become `mydata-YYYY.MM.DD`. The last string appended belongs to the date when the data is being generated. |`logstash`|
37
36
|`Logstash_Prefix_Key`| When included: the value of the key in the record will be evaluated as key reference and overrides `Logstash_Prefix` for index generation. If the key/value isn't found in the record then the `Logstash_Prefix` option will act as a fallback. The parameter is expected to be a [record accessor](../../administration/configuring-fluent-bit/classic-mode/record-accessor.md). ||
38
37
|`Logstash_Prefix_Separator`| Set a separator between `Logstash_Prefix` and date.| - |
39
38
|`Logstash_DateFormat`| Time format based on [strftime](http://man7.org/linux/man-pages/man3/strftime.3.html) to generate the second part of the Index name. |`%Y.%m.%d`|
@@ -45,17 +44,16 @@ operational Elasticsearch service running in your environment.
45
44
|`Generate_ID`| When enabled, generate `_id` for outgoing records. This prevents duplicate records when retrying ES. |`Off`|
46
45
|`Id_Key`| If set, `_id` will be the value of the key from incoming record and `Generate_ID` option is ignored. ||
47
46
|`Write_Operation`|`Write_operation` can be any of: `create`, `index`, `update`, `upsert`. |`create`|
48
-
|`Replace_Dots`| When enabled, replace field name dots with underscore, required by Elasticsearch 2.0-2.3. |`Off`|
49
-
|`Trace_Output`| Print all ElasticSearch API request payloads to `stdout` for diagnostics |`Off`|
50
-
|`Trace_Error`| If ElasticSearch returns an error, print the ElasticSearch API request and response for diagnostics |`Off`|
51
-
|`Current_Time_Index`| Use current time for index generation instead of message record |`Off`|
52
-
| `Suppress_Type_Name` | When enabled, mapping types is removed and `Type` option is
53
-
ignored. Elasticsearch 8.0.0 or higher [no longer supports mapping types](https://www.elastic.co/guide/en/elasticsearch/reference/current/removal-of-types.html), and is set to `On`. | `Off` |
47
+
|`Replace_Dots`| When enabled, replace field name dots with underscore. Required by Elasticsearch 2.0-2.3. |`Off`|
48
+
|`Trace_Output`| Print all ElasticSearch API request payloads to `stdout` for diagnostics. |`Off`|
49
+
|`Trace_Error`| If ElasticSearch returns an error, print the ElasticSearch API request and response for diagnostics. |`Off`|
50
+
|`Current_Time_Index`| Use current time for index generation instead of message record. |`Off`|
51
+
|`Suppress_Type_Name`| When enabled, mapping types is removed and `Type` option is ignored. Elasticsearch 8.0.0 or higher [no longer supports mapping types](https://www.elastic.co/guide/en/elasticsearch/reference/current/removal-of-types.html), and is set to `On`. |`Off`|
54
52
|`Workers`| The number of [workers](../../administration/multithreading.md#outputs) to perform flush operations for this output. |`2`|
55
53
56
-
The parameters `index` and `type` can be confusing if you are new to Elastic, if you
57
-
have used a common relational database before, they can be compared to the`database`
58
-
and `table` concepts. Also see [the FAQ](elasticsearch.md#faq)
54
+
If you have used a common relational database, the parameters `index` and `type` can
55
+
be compared to the `database` and `table` concepts. Also see [the
56
+
FAQ](elasticsearch.md#faq)
59
57
60
58
### TLS / SSL
61
59
@@ -66,14 +64,18 @@ available and general configuration, refer to[TLS/SSL](../../administration/tran
66
64
67
65
The `write_operation` can be any of:
68
66
69
-
| Operation | Description |
70
-
| -------------| ----------- |
71
-
|`create`| Adds new data. If the data already exists (based on its id), the op is skipped.|
67
+
| Operation | Description|
68
+
| ----------- | ----------- |
69
+
|`create`| Adds new data. If the data already exists (based on its id), the op is skipped.|
72
70
|`index`| New data is added while existing data (based on its id) is replaced (reindexed).|
73
-
|`update`| Updates existing data (based on its id). If no data is found, the op is skipped.|
74
-
|`upsert`|Known as merge or insert if the data does not exist, updates if the data exists (based on its id).|
71
+
|`update`| Updates existing data (based on its id). If no data is found, the op is skipped.|
72
+
|`upsert`|Merge or insert if the data doesn't exist, updates if the data exists (based on its id).|
75
73
76
-
**Please note, `Id_Key` or `Generate_ID` is required in update, and upsert scenario.**
74
+
{% hint style="info" %}
75
+
76
+
`Id_Key` or `Generate_ID` is required for `update` and `upsert`.
77
+
78
+
{% endhint %}
77
79
78
80
## Get started
79
81
@@ -82,7 +84,12 @@ command line or through the configuration file:
82
84
83
85
### Command Line
84
86
85
-
The **es** plugin can read the parameters from the command line in two ways, through the **-p** argument (property) or setting them directly through the service URI. The URI format is the following:
87
+
The **es** plugin can read the parameters from the command line in two ways:
88
+
89
+
- Through the `-p` argument (property)
90
+
- Setting them directly through the service URI.
91
+
92
+
The URI format is the following:
86
93
87
94
```text
88
95
es://host:port/index/type
@@ -104,7 +111,7 @@ fluent-bit -i cpu -t cpu -o es -p Host=192.168.2.3 -p Port=9200 \
104
111
105
112
### Configuration File
106
113
107
-
In your main configuration file append the following _Input_ & _Output_ sections. You can visualize this configuration [here](https://link.calyptia.com/qhq)
114
+
In your main configuration file append the following `Input` and `Output` sections. You can visualize this configuration [here](https://link.calyptia.com/qhq)
108
115
109
116
```python
110
117
[INPUT]
@@ -124,7 +131,9 @@ In your main configuration file append the following _Input_ & _Output_ sections
124
131
125
132
## About Elasticsearch field names
126
133
127
-
Some input plugins can generate messages where the field names contains dots, since Elasticsearch 2.0 this is not longer allowed, so the current **es** plugin replaces them with an underscore, e.g:
134
+
Some input plugins can generate messages where the field names contains dots. For
135
+
Elasticsearch 2.0, this isn't allowed. The current **es** plugin replaces
136
+
them with an underscore:
128
137
129
138
```text
130
139
{"cpu0.p_cpu"=>17.000000}
@@ -136,62 +145,21 @@ becomes
136
145
{"cpu0_p_cpu"=>17.000000}
137
146
```
138
147
139
-
## FAQ
140
-
141
-
### Elasticsearch rejects requests saying "the final mapping would have more than 1 type" <aid="faq-multiple-types"></a>
142
-
143
-
Elasticsearch 6.0 can't create multiple types in a single index. This
144
-
means that you can't set up your configuration like the following:.
145
-
146
-
```text
147
-
[OUTPUT]
148
-
Name es
149
-
Match foo.*
150
-
Index search
151
-
Type type1
152
-
153
-
[OUTPUT]
154
-
Name es
155
-
Match bar.*
156
-
Index search
157
-
Type type2
158
-
```
159
-
160
-
An error message like the following indicats you need to update your configuration to
161
-
use a single type on each index.
162
-
163
-
```text
164
-
Rejecting mapping update to [search] as the final mapping would have more than 1 type
165
-
```
166
-
167
-
For details, read [the official blog post on that issue](https://www.elastic.co/guide/en/elasticsearch/reference/6.7/removal-of-types.html).
168
-
169
-
### Elasticsearch rejects requests saying "Document mapping type name can't start with '\_'" <aid="faq-underscore"></a>
148
+
## Use Fluent Bit ElasticSearch plugin with other services
170
149
171
-
Fluent Bit v1.5 changed the default mapping type from `flb_type` to `_doc`, which matches the recommendation from Elasticsearch from version 6.2 forwards \([see commit with rationale](https://github.com/fluent/fluent-bit/commit/04ed3d8104ca8a2f491453777ae6e38e5377817e#diff-c9ae115d3acaceac5efb949edbb21196)\). This doesn't work in Elasticsearch versions 5.6 through 6.1 \([see Elasticsearch discussion and fix](https://discuss.elastic.co/t/cant-use-doc-as-type-despite-it-being-declared-the-preferred-method/113837/9)\). Ensure you set an explicit map \(such as `doc` or `flb_type`\) in the configuration, as seen on the last line:
Connect to Amazon OpenSearch or Elastic Cloud with the ElasticSearch plugin.
185
151
186
-
### Fluent Bit + Amazon OpenSearch Service <aid="#aws-es"></a>
152
+
### Amazon OpenSearch Service
187
153
188
-
The Amazon OpenSearch Service adds an extra security layer where HTTP requests must be signed with AWS Sigv4. Fluent Bit v1.5 introduced full support for Amazon OpenSearch Service with IAM Authentication.
154
+
The Amazon OpenSearch Service adds an extra security layer where HTTP requests must
155
+
be signed with AWS Sigv4. Fluent Bit v1.5 introduced full support for Amazon
156
+
OpenSearch Service with IAM Authentication.
189
157
190
-
See [here](https://github.com/fluent/fluent-bit-docs/tree/43c4fe134611da471e706b0edb2f9acd7cdfdbc3/administration/aws-credentials.md) for details on how AWS credentials are fetched.
158
+
See [details](https://github.com/fluent/fluent-bit-docs/tree/43c4fe134611da471e706b0edb2f9acd7cdfdbc3/administration/aws-credentials.md) on how AWS credentials are fetched.
191
159
192
160
Example configuration:
193
161
194
-
```text
162
+
```text copy
195
163
[OUTPUT]
196
164
Name es
197
165
Match *
@@ -204,16 +172,20 @@ Example configuration:
204
172
tls On
205
173
```
206
174
207
-
Notice that the `Port` is set to `443`, `tls` is enabled, and `AWS_Region` is set.
175
+
Be aware that the `Port` is set to `443`, `tls` is enabled, and `AWS_Region` is set.
208
176
209
-
### Fluent Bit + Elastic Cloud
177
+
### Use Fluent Bit with Elastic Cloud
210
178
211
-
Fluent Bit supports connecting to [Elastic Cloud](https://www.elastic.co/guide/en/cloud/current/ec-getting-started.html) providing just the `cloud_id` and the `cloud_auth` settings.
212
-
`cloud_auth` uses the `elastic` user and password provided when the cluster was created, for details refer to the [Cloud ID usage page](https://www.elastic.co/guide/en/cloud/current/ec-cloud-id.html).
by providing the `cloud_id` and the `cloud_auth` settings. `cloud_auth` uses the
182
+
`elastic` user and password provided when the cluster was created. For details refer
183
+
to the
184
+
[Cloud ID usage page](https://www.elastic.co/guide/en/cloud/current/ec-cloud-id.html).
213
185
214
186
Example configuration:
215
187
216
-
```text
188
+
```text copy
217
189
[OUTPUT]
218
190
Name es
219
191
Include_Tag_Key true
@@ -225,35 +197,99 @@ Example configuration:
225
197
cloud_auth elastic:2vxxxxxxxxYV
226
198
```
227
199
228
-
### Validation Failed: 1: an id must be provided if version type or value are set
200
+
In Elastic Cloud version 8 and great, the type option must be removed by setting
201
+
`Suppress_Type_Name On`.
202
+
203
+
Without this you will see errors like:
204
+
205
+
```text
206
+
{"error":{"root_cause":[{"type":"illegal_argument_exception","reason":"Action/metadata line [1] contains an unknown parameter [_type]"}],"type":"illegal_argument_exception","reason":"Action/metadata line [1] contains an unknown parameter [_type]"},"status":400}
207
+
```
229
208
230
-
Since v1.8.2, Fluent Bit started using `create` method (instead of `index`) for data submission.
231
-
This makes Fluent Bit compatible with Datastream introduced in Elasticsearch 7.9.
209
+
## Troubleshooting
232
210
233
-
If you see `action_request_validation_exception` errors on your pipeline with Fluent Bit >= v1.8.2, you can fix it up by turning on `Generate_ID` as follows:
211
+
Use the following information to help resolve errors using the ElasticSearch plugin.
212
+
213
+
### Using multiple types in a single index
214
+
215
+
Elasticsearch 6.0 can't create multiple types in a single index. An error message
216
+
like the following indicates you need to update your configuration to use a single
217
+
type on each index.
218
+
219
+
```text
220
+
Rejecting mapping update to [products] as the final mapping would have more than 1 type:
221
+
```
222
+
223
+
This means that you can't set up your configuration like the following:.
234
224
235
225
```text
236
226
[OUTPUT]
237
-
Name es
238
-
Match *
239
-
Host 192.168.12.1
240
-
Generate_ID on
227
+
Name es
228
+
Match foo.*
229
+
Index search
230
+
Type type1
231
+
232
+
[OUTPUT]
233
+
Name es
234
+
Match bar.*
235
+
Index search
236
+
Type type2
241
237
```
242
238
243
-
### Action/metadata contains an unknown parameter type
239
+
For details, read [the official blog post on that issue](https://www.elastic.co/guide/en/elasticsearch/reference/6.7/removal-of-types.html).
240
+
241
+
### Mapping type names can't start with underscores (`_`)
244
242
245
-
Elastic Cloud is now on version 8 so the type option must be removed by setting `Suppress_Type_Name On` as indicated above.
243
+
Fluent Bit v1.5 changed the default mapping type from `flb_type` to `_doc`, matching
244
+
the recommendation from Elasticsearch for version 6.2 and greater
In Fluent Bit v1.8.2 and greater, Fluent Bit started using `create` method (instead
270
+
of `index`) for data submission. This makes Fluent Bit compatible with Datastream,
271
+
introduced in Elasticsearch 7.9. You might see errors like:
248
272
249
273
```text
250
-
{"error":{"root_cause":[{"type":"illegal_argument_exception","reason":"Action/metadata line [1] contains an unknown parameter [_type]"}],"type":"illegal_argument_exception","reason":"Action/metadata line [1] contains an unknown parameter [_type]"},"status":400}
274
+
Validation Failed: 1: an id must be provided if version type or value are set
275
+
```
276
+
277
+
If you see `action_request_validation_exception` errors on your pipeline with
278
+
Fluent Bit versions greater than v1.8.2, correct them by turning on `Generate_ID`
279
+
as follows:
280
+
281
+
```text copy
282
+
[OUTPUT]
283
+
Name es
284
+
Match *
285
+
Host 192.168.12.1
286
+
Generate_ID on
251
287
```
252
288
253
-
### Logstash_Prefix_Key
289
+
### `Logstash_Prefix_Key`
254
290
255
291
The following snippet demonstrates using the namespace name as extracted by the
256
-
`kubernetes` filter as logstash prefix:
292
+
`kubernetes` filter as `logstash` prefix:
257
293
258
294
```text
259
295
[OUTPUT]
@@ -265,4 +301,5 @@ The following snippet demonstrates using the namespace name as extracted by the
265
301
# ...
266
302
```
267
303
268
-
For records that do nor have the field `kubernetes.namespace_name`, the default prefix, `logstash` will be used.
304
+
For records that don't have the field `kubernetes.namespace_name`, the default prefix
0 commit comments