9.8 KiB
title | seotitle | weight | description | menu | influxdb/cloud-dedicated/tags | related | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Troubleshoot issues writing data | Troubleshoot issues writing data to InfluxDB | 106 | Troubleshoot issues writing data. Find response codes for failed writes. Discover how writes fail, from exceeding rate or payload limits, to syntax errors and schema conflicts. |
|
|
|
Learn how to avoid unexpected results and recover from errors when writing to {{% product-name %}}.
Handle write responses
{{% product-name %}} does the following when you send a write request:
-
Validates the request.
-
If successful, attempts to ingest data from the request body; otherwise, responds with an error status.
-
Ingests or rejects data in the batch and returns one of the following HTTP status codes:
204 No Content
: all data in the batch is ingested201 Created
(If the cluster is configured to allow partial writes): some points in the batch are ingested and queryable, and some points are rejected400 Bad Request
: all data is rejected
The response body contains error details about rejected points, up to 100 points.
Writes are synchronous--the response status indicates the final status of the write and all ingested data is queryable.
To ensure that InfluxDB handles writes in the order you request them, wait for the response before you send the next request.
Review HTTP status codes
InfluxDB uses conventional HTTP status codes to indicate the success or failure of a request.
The message
property of the response body may contain additional details about the error.
{{< product-name >}} returns one the following HTTP status codes for a write request:
HTTP response code | Response body | Description |
---|---|---|
201 "Created" |
error details about rejected points, up to 100 points: line contains the first rejected line, message describes rejections |
If partial writes are configured for the cluster, and if some of the data is ingested and some of the data is rejected |
204 No Content" |
no response body | If InfluxDB ingested all of the data in the batch |
400 "Bad request" |
error details about rejected points, up to 100 points: line contains the first rejected line, message describes rejections line |
If request data is malformed |
401 "Unauthorized" |
If the Authorization header is missing or malformed or if the token doesn't have permission to write to the database. See examples using credentials in write requests. |
|
404 "Not found" |
requested resource type (for example, "organization" or "database"), and resource name | If a requested resource (for example, organization or database) wasn't found |
422 "Unprocessable Entity" |
message contains details about the error |
If the data isn't allowed (for example, falls outside of the database’s retention period). |
500 "Internal server error" |
Default status for an error | |
503 "Service unavailable" |
If the server is temporarily unavailable to accept writes. The Retry-After header contains the number of seconds to wait before trying the write again. |
The message
property of the response body may contain additional details about the error.
If your data did not write to the database, see how to troubleshoot rejected points.
Troubleshoot failures
If you notice data is missing in your database, do the following:
- Check the HTTP status code in the response.
- Check the
message
property in the response body for details about the error. - If the
message
describes a field error, troubleshoot rejected points. - Verify all lines contain valid syntax (line protocol).
- Verify the timestamps in your data match the precision parameter in your request.
- Minimize payload size and network errors by optimizing writes.
Troubleshoot rejected points
When writing points from a batch, InfluxDB rejects points that have syntax errors or schema conflicts. If InfluxDB processes the data in your batch and then rejects points, the HTTP response body contains the following properties that describe rejected points:
code
:"invalid"
line
: the line number of the first rejected point in the batch.message
: a string that contains line-separated error messages, one message for each rejected point in the batch, up to 100 rejected points.
InfluxDB rejects points for the following reasons:
- a line protocol parsing error
- an invalid timestamp
- a schema conflict
Schema conflicts occur when you try to write data that contains any of the following:
- a wrong data type: the point falls within the same partition (default partitioning is measurement and day) as existing bucket data and contains a different data type for an existing field
- a tag and a field that use the same key
Example
The following example shows a response body for a write request that contains two rejected points:
{
"code": "invalid",
"line": 2,
"message": "failed to parse line protocol:
errors encountered on line(s):
error parsing line 2 (1-based): Invalid measurement was provided
error parsing line 4 (1-based): Unable to parse timestamp value '123461000000000000000000000000'"
}
Check for field data type differences between the rejected data point and points within the same database and partition--for example, did you attempt to write string
data to an int
field?