Use the InfluxDB v1 HTTP API
Use the InfluxDB v1 API /write and /query endpoints with v1 workloads that you bring to InfluxDB Cloud Serverless.
The v1 endpoints work with username/password authentication and existing InfluxDB 1.x tools and code.
Learn how to authenticate requests, map databases and retention policies to buckets, adjust request parameters for existing v1 workloads, and find compatible tools for writing and querying data stored in an InfluxDB Cloud Serverless database.
- Authenticate API requests
- Responses
- Map v1 databases and retention policies to buckets
- Write data
- Query data
- Bucket management with InfluxQL (not supported)
Authenticate API requests
InfluxDB Cloud Serverless requires each API request to be authenticated with an
API token.
With InfluxDB v1-compatible endpoints in InfluxDB 3, you can use API tokens in InfluxDB 1.x username and password
schemes or in the InfluxDB v2 Authorization: Token scheme.
Authenticate with a username and password scheme
With InfluxDB v1-compatible endpoints, you can use the InfluxDB 1.x convention of
username and password to authenticate bucket reads and writes by passing an API token as the password credential.
When authenticating requests to the v1 API /write and /query endpoints, InfluxDB Cloud Serverless checks that the password (p) value is an authorized API token.
InfluxDB Cloud Serverless ignores the username (u) parameter in the request.
Use one of the following authentication schemes with clients that support Basic authentication or query parameters (that don’t support token authentication):
Basic authentication
Use the Authorization header with the Basic scheme to authenticate v1 API /write and /query requests.
When authenticating requests, InfluxDB Cloud Serverless checks that the password part of the decoded credential is an authorized API token.
InfluxDB Cloud Serverless ignores the username part of the decoded credential.
Syntax
Authorization: Basic <base64-encoded [USERNAME]:API_TOKEN>Encode the [USERNAME]:DATABASE_TOKEN credential using base64 encoding, and then append the encoded string to the Authorization: Basic header.
Most HTTP clients provide a Basic authentication option that
accepts the <username>:<password> syntax
and encodes the credentials before sending the request.
Example
The following example shows how to use cURL with the Basic authentication scheme and a token:
#######################################
# Use Basic authentication with a database token
# to query the InfluxDB v1 API
#######################################
curl "https://cloud2.influxdata.com/query" \
--user "any:API_TOKEN" \
--data-urlencode "db=DATABASE_NAME" \
--data-urlencode "rp=RETENTION_POLICY" \
--data-urlencode "q=SELECT * FROM MEASUREMENT"Replace the following:
DATABASE_NAME: your InfluxDB Cloud Serverless bucketRETENTION_POLICY: your InfluxDB Cloud Serverless retention policyAPI_TOKEN: a token with sufficient permissions to the mapped bucket
Query string authentication
In the URL, pass the p query parameter to authenticate /write and /query requests.
When authenticating requests, InfluxDB Cloud Serverless checks that the p (password) value is an authorized API token and ignores the u (username) parameter.
Syntax
https://cloud2.influxdata.com/query/?u=any&p=API_TOKEN
https://cloud2.influxdata.com/write/?u=any&p=API_TOKENExample
The following example shows how to use cURL with query string authentication and a token.
#######################################
# Use an InfluxDB 1.x compatible username and password
# to query the InfluxDB v1 API
#######################################
curl --get "https://cloud2.influxdata.com/query" \
--data-urlencode "p=API_TOKEN" \
--data-urlencode "db=DATABASE_NAME" \
--data-urlencode "rp=RETENTION_POLICY" \
--data-urlencode "q=SELECT * FROM MEASUREMENT"Replace the following:
DATABASE_NAME: the databaseRETENTION_POLICY: the retention policyAPI_TOKEN: a token with sufficient permissions to the mapped bucket
Authenticate with a token scheme
Use the Authorization: Token scheme to pass a token for authenticating
v1 API /write and /query requests.
Include the word Token, a space, and your token value (all case-sensitive).
Syntax
Authorization: Token API_TOKENExamples
Use Token to authenticate a write request:
########################################################
# Use the Token authorization scheme with v1 /write
# to write data.
########################################################
curl -i "https://cloud2.influxdata.com/write?db=DATABASE_NAME&rp=RETENTION_POLICY&precision=ms" \
--header "Authorization: Token API_TOKEN" \
--header "Content-type: text/plain; charset=utf-8" \
--data-binary 'home,room=kitchen temp=72 1682358973500'Replace the following:
DATABASE_NAME: the databaseRETENTION_POLICY: the retention policyAPI_TOKEN: a token with sufficient permissions to the mapped bucket
Responses
InfluxDB HTTP API responses use standard HTTP status codes.
The response body for partial writes and errors contains a JSON object with code and message properties that describe the error.
Response body messages may differ across InfluxDB Cloud Serverless v1 API, v2 API, InfluxDB Cloud, and InfluxDB OSS.
Error examples
Invalid namespace name:
400 Bad Request{ "code":"invalid", "message":"namespace name length must be between 1 and 64 characters" }The
?db=parameter value is missing in the request. Provide the DBRP database name.Failed to deserialize db/rp/precision
400 Bad Request{ "code": "invalid", "message": "failed to deserialize db/rp/precision in request: unknown variant `u`, expected one of `s`, `ms`, `us`, `ns`" }The
?precision=parameter contains an unknown value. Provide a [timestamp precision]/influxdb3/cloud-serverless/reference/glossary/#timestamp-precision).
Map v1 databases and retention policies to buckets
Before you can write data using the InfluxDB v1 /write endpoint or query data using the v1 /query endpoint, the bucket must be mapped to a database retention policy (DBRP) combination.
To query using Flight with InfluxQL or SQL, you don’t need to map DBRPs to buckets.
In InfluxDB 1.x, data is stored in databases and retention policies. In InfluxDB Cloud Serverless, the concepts of database and retention policy have been merged into buckets, where buckets have a retention period, but retention policies are no longer part of the data model.
InfluxDB can automatically map buckets to DBRPs for you or you can manage DBRP mappings yourself using the influx v1 dbrp CLI commands or the InfluxDB v2 API /api/v2/dbrps endpoints.
- Authenticate API requests
- Responses
- Map v1 databases and retention policies to buckets
- Write data
- Query data
- Bucket management with InfluxQL (not supported)
Required permissions
Managing DBRP mappings requires a token with the necessary permissions.
- write dbrp: to create (automatically or manually), update, or delete DBRP mappings.
- read dbrp: to list DBRP mappings
- write bucket: to automatically create a bucket for a DBRP mapping when using the v1 write API
Permission required to create mapped buckets
If you use the v1 write API to write to a database (db) and retention policy (rp) combination that doesn’t exist, InfluxDB tries to create a new bucket using the specified parameter values.
If the token doesn’t have permission to create a bucket, then the write request fails with an authorization error.
Default DBRP
Each unique database name in DBRP mappings has a default mapping (the default property is equal to true).
If you send a request to the v1 /write or v1 /query endpoint and don’t specify a retention policy name (rp=),
then InfluxDB uses the database’s default DBRP mapping to determine the bucket.
Automatic DBRP mapping
InfluxDB Cloud Serverless automatically creates DBRP mappings for you during the following operations:
For InfluxDB to automatically create DBRP mappings and buckets, you must use a token that has write permissions for DBRPs and buckets.
Auto-generated buckets use the name syntax for mapped buckets and a default retention period equal to the bucket’s created date minus 3 days. To set a bucket’s retention period, see how to update a bucket.
Name syntax for mapped buckets
InfluxDB uses the following naming convention to map database and retention policy names to bucket names:
DATABASE_NAME/RETENTION_POLICY_NAMEBucket naming examples
| v1 Database name | v1 Retention Policy name | Bucket name |
|---|---|---|
| db | rp | db/rp |
| telegraf | autogen | telegraf/autogen |
| webmetrics | 1w-downsampled | webmetrics/1w-downsampled |
To avoid having to add configuration parameters to each CLI command, set up an active InfluxDB configuration.
Manage DBRPs
Create DBRP mappings
To create DBRP mappings, use the influx CLI or the
InfluxDB HTTP API.
A DBRP combination can only be mapped to a single bucket
Each unique DBRP combination can only be mapped to a single bucket. If you map a DBRP combination that is already mapped to another bucket, it overwrites the existing DBRP mapping.
Use the influx v1 dbrp create command
to map a database and retention policy to a bucket.
Include the following:
* Required
- * a token that has the necessary permissions to the mapped bucket.
- * the database name to map
- * the retention policy name to map
- * the bucket ID to map to
- Default flag to set the provided retention policy as the default DBRP mapping for the database.
influx v1 dbrp create \
--token API_TOKEN \
--org ORG_ID \
--db DATABASE_NAME \
--rp RETENTION_POLICY_NAME \
--bucket-id BUCKET_ID \
--defaultReplace the following:
API_TOKEN: a token that has the necessary permissions to the mapped bucketDATABASE_NAME: the database name to map to the bucketRETENTION_POLICY_NAME: the retention policy name to map to the bucketBUCKET_ID: the bucket ID to map to
The output is the DBRP.
Use the /api/v2/dbrps API endpoint
to create a new DBRP mapping.
POST https://cloud2.influxdata.com/api/v2/dbrps
Include the following:
Request method:
POSTHeaders:
- Authorization:
Tokenscheme with a token that has the necessary permissions to the mapped bucket - Content-type:
application/json
- Authorization:
Request body: JSON object with the following fields:
- bucketID: the bucket ID to map to
- database: the database name to map to the bucket
- org or orgID: your organization name or organization ID
- retention_policy: the retention policy name to map to the bucket
- Optional: default:
truesets the database name’s default DBRP mapping.
curl --request POST https://cloud2.influxdata.com/api/v2/dbrps \
--header "Authorization: Token API_TOKEN" \
--header 'Content-type: application/json' \
--data '{
"bucketID": "BUCKET_ID",
"database": "DATABASE_NAME",
"default": true,
"orgID": "ORG_ID",
"retention_policy": "RETENTION_POLICY_NAME"
}'If successful, the response status code is 201: Created and the response body contains the DBRP.
List DBRP mappings
Use the influx CLI or the
InfluxDB HTTP API to list all DBRP
mappings and verify that the buckets you want to query are mapped to a database and
retention policy.
Use the influx v1 dbrp list command
to list DBRP mappings.
View all DBRP mappings
influx v1 dbrp list --token API_TOKEN --org ORG_ID \Filter DBRP mappings by database
influx v1 dbrp list \
--token API_TOKEN \
--org ORG_ID \
--db DATABASE_NAMEFilter DBRP mappings by bucket ID
influx v1 dbrp list \
--token API_TOKEN \
--org ORG_ID \
--bucket-id BUCKET_IDUse the /api/v2/dbrps API endpoint to list DBRP mappings.
GET https://cloud2.influxdata.com/api/v2/dbrps
Include the following:
- Request method:
GET - Headers:
- Authorization:
Tokenscheme with your token that has the necessary permissions to the mapped bucket
- Authorization:
- Query parameters:
* Required
- * orgID: your organization ID
- bucketID: a bucket ID (to list DBRP mappings for a specific bucket)
- database: a database name (to list DBRP mappings with a specific database name)
- rp: a retention policy name (to list DBRP mappings with a specific retention policy name)
- id: a DBRP mapping ID (to list a specific DBRP mapping)
View all DBRP mappings
curl --request GET \
https://cloud2.influxdata.com/api/v2/dbrps \
--header "Authorization: Token API_TOKEN" \
--data-urlencode "orgID=ORG_ID"Filter DBRP mappings by database
curl --request GET \
https://cloud2.influxdata.com/api/v2/dbrps \
--header "Authorization: Token API_TOKEN" \
--data-urlencode "orgID=ORG_ID" \
--data-urlencode "db=DATABASE_NAME"Filter DBRP mappings by bucket ID
curl --request GET \
https://cloud2.influxdata.com/api/v2/dbrps \
--header "Authorization: Token API_TOKEN" \
--data-urlencode "orgID=ORG_ID" \
--data-urlencode "bucketID=BUCKET_ID"Update a DBRP mapping
Use the influx CLI or the
InfluxDB HTTP API to update a DBRP mapping–for example, to change the retention policy name or set the mapping as the default for the database name.
Use the influx v1 dbrp update command
to update a DBRP mapping.
Include the following:
- a token that has the necessary permissions to the mapped bucket
- DBRP mapping ID to update
- Optional: Retention policy name to update to
- Optional: Default flag to set the retention policy as the default DBRP mapping for the database name.
Update the default retention policy
influx v1 dbrp update \
--token API_TOKEN \
--org ORG_ID \
--id DBRP_ID \
--rp RETENTION_POLICY_NAME \
--defaultReplace the following:
API_TOKEN: a token that has the necessary permissions to the mapped bucketDBRP_ID: the DBRP ID to updateRETENTION_POLICY_NAME: a retention policy name to map to the bucket
The output is the DBRP.
Use the /api/v2/dbrps/{dbrpID} API endpoint to update DBRP mappings.
PATCH https://cloud2.influxdata.com/api/v2/dbrps/{dbrpID}
Include the following:
* Required
- Request method:
PATCH - Headers:
- * the Authorization:
Tokenscheme with a token that has the necessary permissions to the mapped bucket
- * the Authorization:
- Path parameters:
- * id: the DBRP mapping ID to update
- Query parameters:
- * orgID: your organization ID
- Request body (JSON):
- rp: retention policy name to update to
- default: set the retention policy as the default DBRP mapping for the database name
Update the default retention policy
curl --request PATCH \
https://cloud2.influxdata.com/api/v2/dbrps/DBRP_ID \
--header "Authorization: Token API_TOKEN" \
--data-urlencode "orgID=ORG_ID" \
--data '{
"rp": "RETENTION_POLICY_NAME",
"default": true
}'Replace the following:
API_TOKEN: a token that has the necessary permissions to the mapped bucketDBRP_ID: the DBRP ID to updateRETENTION_POLICY_NAME: a retention policy name to map to the bucket
The output is the DBRP.
Delete a DBRP mapping
Use the influx CLI or the
InfluxDB API to delete a DBRP mapping.
Use the influx v1 dbrp delete command
to delete a DBRP mapping.
Include the following:
* Required
- * a token that has the necessary permissions to the mapped bucket
- * DBRP mapping ID to delete
influx v1 dbrp delete \
--token API_TOKEN \
--org ORG_ID \
--id DBRP_IDThe output is the DBRP.
Use the /api/v2/dbrps/{dbrpID} API endpoint
to delete a DBRP mapping.
DELETE https://cloud2.influxdata.com/api/v2/dbrps/{dbrpID}
Include the following:
* Required
- Request method:
DELETE - Headers:
- * the Authorization:
Tokenscheme with a token that has the necessary permissions to the mapped bucket
- * the Authorization:
- Path parameters:
- * id: DBRP mapping ID to update
- Query parameters:
- * orgID: organization ID
curl --request DELETE \
https://cloud2.influxdata.com/api/v2/dbrps/DBRP_ID \
--header "Authorization: Token API_TOKEN" \
--data-urlencode "orgID=ORG_ID"Replace the following:
API_TOKEN: a token that has the necessary permissions to the mapped bucketDBRP_ID: the DBRP ID to updateORG_ID: the organization ID
Write data
See how to use the InfluxDB Cloud Serverless HTTP write API for InfluxDB v1 or v1.x-compatibility workloads.
Query data
See how to use the InfluxDB Cloud Serverless HTTP query API for InfluxDB v1 or v1.x-compatibility workloads.
Bucket management with InfluxQL (not supported)
InfluxDB Cloud Serverless doesn’t allow InfluxQL commands for managing or modifying buckets. You can’t use the following InfluxQL commands:
SELECT INTO
CREATE
DELETE
DROP
GRANT
EXPLAIN
REVOKE
ALTER
SET
KILLWas this page helpful?
Thank you for your feedback!
Support and feedback
Thank you for being part of our community! We welcome and encourage your feedback and bug reports for InfluxDB Cloud Serverless and this documentation. To find support, use the following resources:
Customers with an annual or support contract can contact InfluxData Support.