-
Notifications
You must be signed in to change notification settings - Fork 112
HTTP Endpoints
The Influx Proxy API provides a simple way to interact with the influx proxy server. It uses HTTP response codes, HTTP authentication, and basic authentication, and responses are returned in JSON.
Endpoint | Description |
---|---|
/ping | Use /ping to check the status of your InfluxDB Proxy instance and your version of InfluxDB Proxy. |
/query | Use /query to query data and manage databases and measurements. |
/write | Use /write to write data to a pre-existing database. |
/health | Use /health to view health status of all influxdb backends. |
/replica | Use /replica to query replica backends with database and measurement. |
/encrypt | Use /encrypt to encrypt plain username and password. |
/decrypt | Use /decrypt to decrypt ciphered username and password. |
/rebalance | Use /rebalance to rebalance measurements of specific circle. |
/recovery | Use /recovery to recovery measurements from one circle to another circle. |
/resync | Use /resync to resync measurements with each other. |
/cleanup | Use /cleanup to cleanup misplaced measurements of specific circle. |
/transfer/state | Use /transfer/state to get or set transfer state. |
/transfer/stats | Use /transfer/stats to query transfer stats when transferring. |
/debug/pprof | Use /debug/pprof to generate profiles for troubleshooting. |
The following sections assume your InfluxDB Proxy instance is running on 127.0.0.1:7076
and HTTPS is not enabled.
official reference:
official reference:
official reference:
GET http://127.0.0.1:7076/health
Query String Parameter | Optional/Required | Description |
---|---|---|
stats=false | Optional | Return more detailed stats information |
pretty=true | Optional | Enables pretty-printed JSON output. |
u=<username> | Optional if you haven't enabled authentication | Set the username for authentication if you've enabled authentication. |
p=<password> | Optional if you haven't enabled authentication | Set the password for authentication if you've enabled authentication. |
$ curl 'http://127.0.0.1:7076/health?stats=true&pretty=true'
[
{
"circle": {
"id": 0,
"name": "circle-1",
"active": true,
"write_only": false
},
"backends": [
{
"name": "influxdb-1-1",
"url": "http://127.0.0.1:8086",
"active": true,
"backlog": false,
"rewrite": false,
"healthy": true,
"stats": {
"db1": {
"incorrect": 0,
"inplace": 2,
"measurements": 2
},
"db2": {
"incorrect": 0,
"inplace": 4,
"measurements": 4
}
}
}
]
},
...
]
Field description:
circle:
- id: circle id
- name: circle name
- active: whether all influxdb instances of circle are active
- write_only: whether circle is write-only
backends:
- name: influxdb name
- url: influxdb url
- active: whether the influxdb is running
- backlog: is there failed data in the cache file to influxdb
- rewrite: whether the cache data is being rewritten to influxdb
- healthy:whether influxdb is healthy, it's true when each incorrect equals 0 in stats
- stats: influxdb stats of databases
- db: influxdb database
- incorrect: number of measurements which should not be stored on this influxdb
- it's healthy when incorrect equals 0
- inplace: number of measurements which should be stored on this influxdb
- it's healthy when inplace equals the number of measurements in this database
- measurements: number of measurements in this database
measurements = incorrect + inplace
- the number of measurements in each influxdb instance is roughly the same, indicating that the data store is load balanced
- incorrect: number of measurements which should not be stored on this influxdb
- db: influxdb database
GET http://127.0.0.1:7076/replica
Query String Parameter | Optional/Required | Description |
---|---|---|
db=<database> | Required | Database name for replica backends query. |
meas=<measurement> | Required | Measurement name for replica backends query. |
pretty=true | Optional | Enables pretty-printed JSON output. |
u=<username> | Optional if you haven't enabled authentication | Set the username for authentication if you've enabled authentication. |
p=<password> | Optional if you haven't enabled authentication | Set the password for authentication if you've enabled authentication. |
$ curl 'http://127.0.0.1:7076/replica?db=db1&meas=cpu1&pretty=true'
[
{
"backend": {
"name": "influxdb-1-2",
"url": "http://127.0.0.1:8087"
},
"circle": {
"id": 0,
"name": "circle-1"
}
},
{
"backend": {
"name": "influxdb-2-2",
"url": "http://127.0.0.1:8089"
},
"circle": {
"id": 1,
"name": "circle-2"
}
}
]
GET http://127.0.0.1:7076/encrypt
Query String Parameter | Optional/Required | Description |
---|---|---|
text=<text> | Required | The plain text to encrypt. |
$ curl -G 'http://127.0.0.1:7076/encrypt' --data-urlencode 'text=admin'
YgvEyuPZlDYAH8sGDkC!Ag
GET http://127.0.0.1:7076/decrypt
Query String Parameter | Optional/Required | Description |
---|---|---|
key=<key> | Required | The key to encrypt and decrypt, default is consistentcipher. |
text=<text> | Required | The ciphered text to decrypt. |
$ curl 'http://127.0.0.1:7076/decrypt?key=consistentcipher&text=YgvEyuPZlDYAH8sGDkC!Ag'
admin
POST http://127.0.0.1:7076/rebalance
Query String Parameter | Optional/Required | Description |
---|---|---|
circle_id=0 | Required | Circle index started from 0. |
operation=<operation> | Required | Operation type, valid options are add or rm. |
dbs=<dbs> | Optional | Comma-separated database list while using all databases if empty. |
worker=1 | Optional | Concurrent worker's number when transfer, default is 1. |
batch=25000 | Optional | Write batch when transfer, default is 25000. |
limit=1000000 | Optional | Query limit when transfer, default is 1000000. |
ha_addrs=<ha_addrs> | Required if at least two InfluxDB Proxy instances are running | High available addresses (host1:port1,host2:port2... ) of all running InfluxDB Proxy for two instances at least, comma-separated. |
u=<username> | Optional if you haven't enabled authentication | Set the username for authentication if you've enabled authentication. |
p=<password> | Optional if you haven't enabled authentication | Set the password for authentication if you've enabled authentication. |
Json body for describing backends to remove, required when operation is rm
{
"backends": [
{
"name": "influxdb-1-2",
"url": "http://127.0.0.1:8087",
"username": "",
"password": "",
"auth_encrypt": false
}
]
}
Rebalance measurements of circle specified by circle_id after adding backends and restarting InfluxDB Proxy instance
$ curl -X POST 'http://127.0.0.1:7076/rebalance?circle_id=0&operation=add'
accepted
Rebalance measurements of circle specified by circle_id after adding backends, while there are two running InfluxDB Proxy instances for high availability
$ curl -X POST 'http://127.0.0.1:7076/rebalance?circle_id=0&operation=add&ha_addrs=127.0.0.1:7076,127.0.0.1:7077'
accepted
Rebalance measurements of circle specified by circle_id after removing backends, if there is only one running InfluxDB Proxy instances
$ curl -X POST 'http://127.0.0.1:7076/rebalance?circle_id=0&operation=rm&worker=2' -H 'Content-Type: application/json' -d \
'{
"backends": [
{
"name": "influxdb-1-2",
"url": "http://127.0.0.1:8087",
"username": "",
"password": "",
"auth_encrypt": false
}
]
}'
accepted
POST http://127.0.0.1:7076/recovery
Query String Parameter | Optional/Required | Description |
---|---|---|
from_circle_id=0 | Required | From circle index started from 0. |
to_circle_id=1 | Required | To circle index started from 0. |
backend_urls=<backend_urls> | Optional | Comma-separated backend urls to recovery while using all backends of circle specified by to_circle_id if empty. |
dbs=<dbs> | Optional | Comma-separated database list while using all databases if empty. |
worker=1 | Optional | Concurrent worker's number when transfer, default is 1. |
batch=25000 | Optional | Write batch when transfer, default is 25000. |
limit=1000000 | Optional | Query limit when transfer, default is 1000000. |
ha_addrs=<ha_addrs> | Required if at least two InfluxDB Proxy instances are running | High available addresses (host1:port1,host2:port2... ) of all running InfluxDB Proxy for two instances at least, comma-separated. |
u=<username> | Optional if you haven't enabled authentication | Set the username for authentication if you've enabled authentication. |
p=<password> | Optional if you haven't enabled authentication | Set the password for authentication if you've enabled authentication. |
Recovery all backends of circle 1 from circle 0
$ curl -X POST 'http://127.0.0.1:7076/recovery?from_circle_id=0&to_circle_id=1'
accepted
Only recovery backend http://127.0.0.1:8089 in circle 1 from circle 0
$ curl -X POST 'http://127.0.0.1:7076/recovery?from_circle_id=0&to_circle_id=1&backend_urls=http://127.0.0.1:8089'
accepted
POST http://127.0.0.1:7076/resync
Query String Parameter | Optional/Required | Description |
---|---|---|
tick=<tick> | Optional | Resync data from a 10-digital unix time, default is 0 for all data. |
dbs=<dbs> | Optional | Comma-separated database list while using all databases if empty. |
worker=1 | Optional | Concurrent worker's number when transfer, default is 1. |
batch=25000 | Optional | Write batch when transfer, default is 25000. |
limit=1000000 | Optional | Query limit when transfer, default is 1000000. |
ha_addrs=<ha_addrs> | Required if at least two InfluxDB Proxy instances are running | High available addresses (host1:port1,host2:port2... ) of all running InfluxDB Proxy for two instances at least, comma-separated. |
u=<username> | Optional if you haven't enabled authentication | Set the username for authentication if you've enabled authentication. |
p=<password> | Optional if you haven't enabled authentication | Set the password for authentication if you've enabled authentication. |
$ curl -X POST 'http://127.0.0.1:7076/resync?worker=2'
accepted
POST http://127.0.0.1:7076/cleanup
Query String Parameter | Optional/Required | Description |
---|---|---|
circle_id=0 | Required | Circle index started from 0. |
worker=1 | Optional | Concurrent worker's number when transfer, default is 1. |
batch=25000 | Optional | Write batch when transfer, default is 25000. |
limit=1000000 | Optional | Query limit when transfer, default is 1000000. |
ha_addrs=<ha_addrs> | Required if at least two InfluxDB Proxy instances are running | High available addresses (host1:port1,host2:port2... ) of all running InfluxDB Proxy for two instances at least, comma-separated. |
u=<username> | Optional if you haven't enabled authentication | Set the username for authentication if you've enabled authentication. |
p=<password> | Optional if you haven't enabled authentication | Set the password for authentication if you've enabled authentication. |
$ curl -X POST 'http://127.0.0.1:7076/cleanup?circle_id=0&worker=2'
accepted
GET http://127.0.0.1:7076/transfer/state
POST http://127.0.0.1:7076/transfer/state
Query String Parameter | Optional/Required | Description |
---|---|---|
resyncing=true | Optional | Set resyncing state of proxy. |
circle_id=0 | Optional | Circle index to set transferring state, started from 0. |
transferring=false | Optional | Set transferring state of circle specified by circle_id. |
pretty=true | Optional | Enables pretty-printed JSON output. |
u=<username> | Optional if you haven't enabled authentication | Set the username for authentication if you've enabled authentication. |
p=<password> | Optional if you haven't enabled authentication | Set the password for authentication if you've enabled authentication. |
Get transfer state
$ curl 'http://127.0.0.1:7076/transfer/state?pretty=true'
{
"circles": [
{
"id": 0,
"name": "circle-1",
"transferring": false
},
{
"id": 1,
"name": "circle-2",
"transferring": false
}
],
"resyncing": false
}
Set resyncing state of proxy
$ curl -X POST 'http://127.0.0.1:7076/transfer/state?resyncing=true&pretty=true'
{
"resyncing": true
}
Set transferring state of circle 0
$ curl -X POST 'http://127.0.0.1:7076/transfer/state?circle_id=0&transferring=true&pretty=true'
{
"circle": {
"id": 0,
"name": "circle-1",
"transferring": true
}
}
GET http://127.0.0.1:7076/transfer/stats
Query String Parameter | Optional/Required | Description |
---|---|---|
circle_id=0 | Required | Circle index started from 0. |
type=<type> | Required | Stats type, valid options are rebalance, recovery, resync or cleanup. |
pretty=true | Optional | Enables pretty-printed JSON output. |
u=<username> | Optional if you haven't enabled authentication | Set the username for authentication if you've enabled authentication. |
p=<password> | Optional if you haven't enabled authentication | Set the password for authentication if you've enabled authentication. |
$ curl 'http://127.0.0.1:7076/transfer/stats?circle_id=0&type=rebalance&pretty=true'
{
"http://127.0.0.1:8086": {
"database_total": 0,
"database_done": 0,
"measurement_total": 0,
"measurement_done": 0,
"transfer_count": 0,
"inplace_count": 0
},
"http://127.0.0.1:8087": {
"database_total": 0,
"database_done": 0,
"measurement_total": 0,
"measurement_done": 0,
"transfer_count": 0,
"inplace_count": 0
}
}
official reference: