2022-02-07 16:51:46 +01:00
## `influxasync` sink
The `influxasync` sink uses the official [InfluxDB golang client ](https://pkg.go.dev/github.com/influxdata/influxdb-client-go/v2 ) to write the metrics to an InfluxDB database in a **non-blocking** fashion. It provides only support for V2 write endpoints (InfluxDB 1.8.0 or later).
### Configuration structure
```json
{
"< name > ": {
"type": "influxasync",
"database" : "mymetrics",
"host": "dbhost.example.com",
"port": "4222",
"user": "exampleuser",
"password" : "examplepw",
"organization": "myorg",
"ssl": true,
"batch_size": 200,
2022-03-11 13:43:03 +01:00
"retry_interval" : "1s",
"retry_exponential_base" : 2,
2024-12-19 23:00:14 +01:00
"precision": "s",
2022-03-11 13:43:03 +01:00
"max_retries": 20,
2023-10-10 11:56:42 +02:00
"max_retry_time" : "168h",
2024-12-19 23:00:14 +01:00
"process_messages" : {
"see" : "docs of message processor for valid fields"
},
"meta_as_tags" : []
2022-02-07 16:51:46 +01:00
}
}
```
- `type` : makes the sink an `influxdb` sink
- `database` : All metrics are written to this bucket
- `host` : Hostname of the InfluxDB database server
- `port` : Portnumber (as string) of the InfluxDB database server
- `user` : Username for basic authentification
- `password` : Password for basic authentification
- `organization` : Organization in the InfluxDB
- `ssl` : Use SSL connection
2022-03-11 13:43:03 +01:00
- `batch_size` : batch up metrics internally, default 100
- `retry_interval` : Base retry interval for failed write requests, default 1s
- `retry_exponential_base` : The retry interval is exponentially increased with this base, default 2
- `max_retries` : Maximal number of retry attempts
- `max_retry_time` : Maximal time to retry failed writes, default 168h (one week)
2024-12-19 23:00:14 +01:00
- `precision` : Precision of the timestamp. Valid values are 's', 'ms', 'us' and 'ns'. (default is 's')
- `process_messages` : Process messages with given rules before progressing or dropping, see [here ](../pkg/messageProcessor/README.md ) (optional)
- `meta_as_tags` : print all meta information as tags in the output (deprecated, optional)
2022-03-11 13:43:03 +01:00
2023-10-10 11:56:42 +02:00
For information about the calculation of the retry interval settings, see [offical influxdb-client-go documentation ](https://github.com/influxdata/influxdb-client-go#handling-of-failed-async-writes )
2024-12-19 23:00:14 +01:00
### Using `influxasync` sink for communication with cc-metric-store
The cc-metric-store only accepts metrics with a timestamp precision in seconds, so it is required to use `"precision": "s"` .