Query data with the InfluxDB JavaScript client library
Use the InfluxDB JavaScript client library in a Node.js environment to query InfluxDB.
The following example sends a Flux query to an InfluxDB bucket and outputs rows from an observable table.
Before you begin
Query InfluxDB
Change to your new project directory and create a file for your query module.
cd influx-node-app && touch query.js
Instantiate an
InfluxDB
client. Provide your InfluxDB URL and API token. Use thegetQueryApi()
method of the client. Provide your InfluxDB organization ID to create a configured query client.import { InfluxDB, Point } from '@influxdata/influxdb-client'
const queryApi = new InfluxDB({YOUR_URL, YOUR_API_TOKEN}).getQueryApi(YOUR_ORG)
Replace the following:
YOUR_URL
: InfluxDB URLYOUR_API_TOKEN
: InfluxDB API tokenYOUR_ORG
: InfluxDB organization ID
Create a Flux query for your InfluxDB bucket. Store the query as a string variable.
To prevent SQL injection attacks, avoid concatenating unsafe user input with queries.
const fluxQuery =
'from(bucket: "YOUR_BUCKET")
|> range(start: 0)
|> filter(fn: (r) => r._measurement == "temperature")'
Replace
YOUR_BUCKET
with the name of your InfluxDB bucket.Use the
queryRows()
method of the query client to query InfluxDB.queryRows()
takes a Flux query and an RxJS Observer object. The client returns table metadata and rows as an RxJS Observable.queryRows()
subscribes your observer to the observable. Finally, the observer logs the rows from the response to the terminal.const observer = {
next(row, tableMeta) {
const o = tableMeta.toObject(row)
console.log(
`${o._time} ${o._measurement} in '${o.location}' (${o.sensor_id}): ${o._field}=${o._value}`
)
}
}
queryApi.queryRows(fluxQuery, observer)
Complete example
'use strict'
/** @module query
* Queries a data point in InfluxDB using the Javascript client library with Node.js.
**/
import { InfluxDB, Point } from '@influxdata/influxdb-client'
/** Environment variables **/
const url = process.env.INFLUX_URL || ''
const token = process.env.INFLUX_TOKEN
const org = process.env.INFLUX_ORG || ''
/**
* Instantiate the InfluxDB client
* with a configuration object.
*
* Get a query client configured for your org.
**/
const queryApi = new InfluxDB({url, token}).getQueryApi(org)
/** To avoid SQL injection, use a string literal for the query. */
const fluxQuery = 'from(bucket:"air_sensor") |> range(start: 0) |> filter(fn: (r) => r._measurement == "temperature")'
const fluxObserver = {
next(row, tableMeta) {
const o = tableMeta.toObject(row)
console.log(
`${o._time} ${o._measurement} in ${o.region} (${o.sensor_id}): ${o._field}=${o._value}`
)
},
error(error) {
console.error(error)
console.log('\nFinished ERROR')
},
complete() {
console.log('\nFinished SUCCESS')
}
}
/** Execute a query and receive line table metadata and rows. */
queryApi.queryRows(fluxQuery, fluxObserver)
To run the example from a file, set your InfluxDB environment variables and use node
to execute the JavaScript file.
export INFLUX_URL=http://localhost:8086 && \
export INFLUX_TOKEN=YOUR_API_TOKEN && \
export INFLUX_ORG=YOUR_ORG && \
node query.js
For more examples and information, see the JavaScript client on GitHub.