2015-03-27 15:56:00 +00:00
|
|
|
# InfluxDB Client
|
2015-01-22 22:08:30 +00:00
|
|
|
|
2016-02-10 17:26:18 +00:00
|
|
|
[![GoDoc](https://godoc.org/github.com/influxdata/influxdb?status.svg)](http://godoc.org/github.com/influxdata/influxdb/client/v2)
|
2015-07-08 14:25:59 +00:00
|
|
|
|
2015-03-27 15:56:00 +00:00
|
|
|
## Description
|
|
|
|
|
2015-10-09 02:00:30 +00:00
|
|
|
**NOTE:** The Go client library now has a "v2" version, with the old version
|
|
|
|
being deprecated. The new version can be imported at
|
2016-02-10 17:26:18 +00:00
|
|
|
`import "github.com/influxdata/influxdb/client/v2"`. It is not backwards-compatible.
|
2015-10-09 02:00:30 +00:00
|
|
|
|
2015-03-27 20:01:45 +00:00
|
|
|
A Go client library written and maintained by the **InfluxDB** team.
|
2015-03-27 15:56:00 +00:00
|
|
|
This package provides convenience functions to read and write time series data.
|
|
|
|
It uses the HTTP protocol to communicate with your **InfluxDB** cluster.
|
|
|
|
|
|
|
|
|
|
|
|
## Getting Started
|
|
|
|
|
|
|
|
### Connecting To Your Database
|
|
|
|
|
2015-03-27 20:01:45 +00:00
|
|
|
Connecting to an **InfluxDB** database is straightforward. You will need a host
|
2015-10-09 02:00:30 +00:00
|
|
|
name, a port and the cluster user credentials if applicable. The default port is
|
|
|
|
8086. You can customize these settings to your specific installation via the
|
2015-03-27 20:01:45 +00:00
|
|
|
**InfluxDB** configuration file.
|
|
|
|
|
2016-02-10 22:45:17 +00:00
|
|
|
Though not necessary for experimentation, you may want to create a new user
|
2015-03-27 20:01:45 +00:00
|
|
|
and authenticate the connection to your database.
|
|
|
|
|
|
|
|
For more information please check out the
|
2016-04-11 13:56:53 +00:00
|
|
|
[Admin Docs](https://docs.influxdata.com/influxdb/latest/administration/).
|
2015-03-27 20:01:45 +00:00
|
|
|
|
2015-03-27 22:29:41 +00:00
|
|
|
For the impatient, you can create a new admin user _bubba_ by firing off the
|
2016-02-10 17:26:18 +00:00
|
|
|
[InfluxDB CLI](https://github.com/influxdata/influxdb/blob/master/cmd/influx/main.go).
|
2015-03-27 20:01:45 +00:00
|
|
|
|
|
|
|
```shell
|
|
|
|
influx
|
|
|
|
> create user bubba with password 'bumblebeetuna'
|
|
|
|
> grant all privileges to bubba
|
|
|
|
```
|
|
|
|
|
|
|
|
And now for good measure set the credentials in you shell environment.
|
|
|
|
In the example below we will use $INFLUX_USER and $INFLUX_PWD
|
|
|
|
|
2015-03-27 22:29:41 +00:00
|
|
|
Now with the administrivia out of the way, let's connect to our database.
|
2015-03-27 20:01:45 +00:00
|
|
|
|
2015-03-27 22:29:41 +00:00
|
|
|
NOTE: If you've opted out of creating a user, you can omit Username and Password in
|
|
|
|
the configuration below.
|
2015-03-27 15:56:00 +00:00
|
|
|
|
|
|
|
```go
|
|
|
|
package main
|
|
|
|
|
2015-08-30 11:51:18 +00:00
|
|
|
import (
|
2015-10-09 02:00:30 +00:00
|
|
|
"net/url"
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"os"
|
|
|
|
|
2016-02-10 17:26:18 +00:00
|
|
|
"github.com/influxdata/influxdb/client/v2"
|
2015-08-30 11:51:18 +00:00
|
|
|
)
|
2015-03-27 15:56:00 +00:00
|
|
|
|
|
|
|
const (
|
2015-10-09 02:00:30 +00:00
|
|
|
MyDB = "square_holes"
|
|
|
|
username = "bubba"
|
|
|
|
password = "bumblebeetuna"
|
2015-03-27 15:56:00 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2015-10-09 02:00:30 +00:00
|
|
|
// Make client
|
2016-01-09 20:13:13 +00:00
|
|
|
c, err := client.NewHTTPClient(client.HTTPConfig{
|
2015-11-18 16:54:37 +00:00
|
|
|
Addr: "http://localhost:8086",
|
2015-10-09 02:00:30 +00:00
|
|
|
Username: username,
|
|
|
|
Password: password,
|
|
|
|
})
|
2016-04-11 13:56:53 +00:00
|
|
|
|
2016-01-09 20:13:13 +00:00
|
|
|
if err != nil {
|
2016-01-19 12:35:30 +00:00
|
|
|
log.Fatalln("Error: ", err)
|
|
|
|
}
|
2016-04-11 13:56:53 +00:00
|
|
|
|
2015-10-09 02:00:30 +00:00
|
|
|
// Create a new point batch
|
2016-01-09 20:13:13 +00:00
|
|
|
bp, err := client.NewBatchPoints(client.BatchPointsConfig{
|
2015-10-09 02:00:30 +00:00
|
|
|
Database: MyDB,
|
|
|
|
Precision: "s",
|
|
|
|
})
|
2016-04-11 13:56:53 +00:00
|
|
|
|
2016-01-09 20:13:13 +00:00
|
|
|
if err != nil {
|
2016-01-19 12:35:30 +00:00
|
|
|
log.Fatalln("Error: ", err)
|
|
|
|
}
|
2015-10-09 02:00:30 +00:00
|
|
|
|
|
|
|
// Create a point and add to batch
|
|
|
|
tags := map[string]string{"cpu": "cpu-total"}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"idle": 10.1,
|
|
|
|
"system": 53.3,
|
|
|
|
"user": 46.6,
|
2015-03-27 15:56:00 +00:00
|
|
|
}
|
2016-01-09 20:13:13 +00:00
|
|
|
pt, err := client.NewPoint("cpu_usage", tags, fields, time.Now())
|
2016-04-11 13:56:53 +00:00
|
|
|
|
2016-01-09 20:13:13 +00:00
|
|
|
if err != nil {
|
2016-01-19 12:39:08 +00:00
|
|
|
log.Fatalln("Error: ", err)
|
|
|
|
}
|
2016-04-11 13:56:53 +00:00
|
|
|
|
2015-10-09 02:00:30 +00:00
|
|
|
bp.AddPoint(pt)
|
2015-03-27 15:56:00 +00:00
|
|
|
|
2015-10-09 02:00:30 +00:00
|
|
|
// Write the batch
|
|
|
|
c.Write(bp)
|
2015-03-27 15:56:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
### Inserting Data
|
|
|
|
|
|
|
|
Time series data aka *points* are written to the database using batch inserts.
|
2015-10-09 02:00:30 +00:00
|
|
|
The mechanism is to create one or more points and then create a batch aka
|
|
|
|
*batch points* and write these to a given database and series. A series is a
|
|
|
|
combination of a measurement (time/values) and a set of tags.
|
2015-03-27 15:56:00 +00:00
|
|
|
|
2015-04-23 17:44:16 +00:00
|
|
|
In this sample we will create a batch of a 1,000 points. Each point has a time and
|
2015-03-27 15:56:00 +00:00
|
|
|
a single value as well as 2 tags indicating a shape and color. We write these points
|
|
|
|
to a database called _square_holes_ using a measurement named _shapes_.
|
|
|
|
|
2015-03-27 20:01:45 +00:00
|
|
|
NOTE: You can specify a RetentionPolicy as part of the batch points. If not
|
2015-10-09 02:00:30 +00:00
|
|
|
provided InfluxDB will use the database _default_ retention policy.
|
2015-03-27 15:56:00 +00:00
|
|
|
|
|
|
|
```go
|
2015-10-09 02:00:30 +00:00
|
|
|
func writePoints(clnt client.Client) {
|
|
|
|
sampleSize := 1000
|
2015-03-27 15:56:00 +00:00
|
|
|
rand.Seed(42)
|
2015-10-09 02:00:30 +00:00
|
|
|
|
|
|
|
bp, _ := client.NewBatchPoints(client.BatchPointsConfig{
|
|
|
|
Database: "systemstats",
|
|
|
|
Precision: "us",
|
|
|
|
})
|
|
|
|
|
2015-03-27 15:56:00 +00:00
|
|
|
for i := 0; i < sampleSize; i++ {
|
2015-10-09 02:00:30 +00:00
|
|
|
regions := []string{"us-west1", "us-west2", "us-west3", "us-east1"}
|
|
|
|
tags := map[string]string{
|
|
|
|
"cpu": "cpu-total",
|
|
|
|
"host": fmt.Sprintf("host%d", rand.Intn(1000)),
|
|
|
|
"region": regions[rand.Intn(len(regions))],
|
2015-03-27 15:56:00 +00:00
|
|
|
}
|
|
|
|
|
2015-10-09 02:00:30 +00:00
|
|
|
idle := rand.Float64() * 100.0
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"idle": idle,
|
|
|
|
"busy": 100.0 - idle,
|
|
|
|
}
|
|
|
|
|
|
|
|
bp.AddPoint(client.NewPoint(
|
|
|
|
"cpu_usage",
|
|
|
|
tags,
|
|
|
|
fields,
|
|
|
|
time.Now(),
|
|
|
|
))
|
2015-03-27 15:56:00 +00:00
|
|
|
}
|
2015-10-09 02:00:30 +00:00
|
|
|
|
|
|
|
err := clnt.Write(bp)
|
2015-03-27 15:56:00 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### Querying Data
|
|
|
|
|
2015-03-27 22:29:41 +00:00
|
|
|
One nice advantage of using **InfluxDB** the ability to query your data using familiar
|
|
|
|
SQL constructs. In this example we can create a convenience function to query the database
|
|
|
|
as follows:
|
2015-03-27 15:56:00 +00:00
|
|
|
|
|
|
|
```go
|
2015-03-27 22:29:41 +00:00
|
|
|
// queryDB convenience function to query the database
|
2015-10-09 02:00:30 +00:00
|
|
|
func queryDB(clnt client.Client, cmd string) (res []client.Result, err error) {
|
2015-03-27 15:56:00 +00:00
|
|
|
q := client.Query{
|
|
|
|
Command: cmd,
|
|
|
|
Database: MyDB,
|
|
|
|
}
|
2015-10-09 02:00:30 +00:00
|
|
|
if response, err := clnt.Query(q); err == nil {
|
2015-03-31 16:26:00 +00:00
|
|
|
if response.Error() != nil {
|
|
|
|
return res, response.Error()
|
2015-03-27 15:56:00 +00:00
|
|
|
}
|
2015-03-31 16:26:00 +00:00
|
|
|
res = response.Results
|
2016-01-12 10:50:35 +00:00
|
|
|
} else {
|
|
|
|
return res, err
|
2015-03-27 15:56:00 +00:00
|
|
|
}
|
2015-10-18 08:39:37 +00:00
|
|
|
return res, nil
|
2015-03-27 15:56:00 +00:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-03-27 22:29:41 +00:00
|
|
|
#### Creating a Database
|
2015-10-09 02:00:30 +00:00
|
|
|
|
2015-03-27 15:56:00 +00:00
|
|
|
```go
|
2015-10-09 02:00:30 +00:00
|
|
|
_, err := queryDB(clnt, fmt.Sprintf("CREATE DATABASE %s", MyDB))
|
2015-03-27 15:56:00 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
#### Count Records
|
2015-10-09 02:00:30 +00:00
|
|
|
|
2015-03-27 15:56:00 +00:00
|
|
|
```go
|
2015-10-09 02:00:30 +00:00
|
|
|
q := fmt.Sprintf("SELECT count(%s) FROM %s", "value", MyMeasurement)
|
|
|
|
res, err := queryDB(clnt, q)
|
2015-03-27 15:56:00 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
count := res[0].Series[0].Values[0][1]
|
2015-10-09 02:00:30 +00:00
|
|
|
log.Printf("Found a total of %v records\n", count)
|
2015-03-27 15:56:00 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
#### Find the last 10 _shapes_ records
|
|
|
|
|
|
|
|
```go
|
2015-10-09 02:00:30 +00:00
|
|
|
q := fmt.Sprintf("SELECT * FROM %s LIMIT %d", MyMeasurement, 20)
|
|
|
|
res, err = queryDB(clnt, q)
|
2015-03-27 15:56:00 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
for i, row := range res[0].Series[0].Values {
|
|
|
|
t, err := time.Parse(time.RFC3339, row[0].(string))
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
2015-09-21 18:33:44 +00:00
|
|
|
val := row[1].(string)
|
|
|
|
log.Printf("[%2d] %s: %s\n", i, t.Format(time.Stamp), val)
|
2015-03-27 15:56:00 +00:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-11-03 20:20:52 +00:00
|
|
|
### Using the UDP Client
|
|
|
|
|
|
|
|
The **InfluxDB** client also supports writing over UDP.
|
|
|
|
|
|
|
|
```go
|
|
|
|
func WriteUDP() {
|
|
|
|
// Make client
|
|
|
|
c := client.NewUDPClient("localhost:8089")
|
|
|
|
|
|
|
|
// Create a new point batch
|
|
|
|
bp, _ := client.NewBatchPoints(client.BatchPointsConfig{
|
|
|
|
Precision: "s",
|
|
|
|
})
|
|
|
|
|
|
|
|
// Create a point and add to batch
|
|
|
|
tags := map[string]string{"cpu": "cpu-total"}
|
|
|
|
fields := map[string]interface{}{
|
|
|
|
"idle": 10.1,
|
|
|
|
"system": 53.3,
|
|
|
|
"user": 46.6,
|
|
|
|
}
|
|
|
|
pt, err := client.NewPoint("cpu_usage", tags, fields, time.Now())
|
|
|
|
if err != nil {
|
|
|
|
panic(err.Error())
|
|
|
|
}
|
|
|
|
bp.AddPoint(pt)
|
|
|
|
|
|
|
|
// Write the batch
|
|
|
|
c.Write(bp)
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-03-27 15:56:00 +00:00
|
|
|
## Go Docs
|
|
|
|
|
|
|
|
Please refer to
|
2016-02-10 17:26:18 +00:00
|
|
|
[http://godoc.org/github.com/influxdata/influxdb/client/v2](http://godoc.org/github.com/influxdata/influxdb/client/v2)
|
2015-03-09 19:07:50 +00:00
|
|
|
for documentation.
|
2015-03-07 14:57:30 +00:00
|
|
|
|
2015-03-27 15:56:00 +00:00
|
|
|
## See Also
|
|
|
|
|
2015-03-27 22:29:41 +00:00
|
|
|
You can also examine how the client library is used by the
|
2016-02-10 17:26:18 +00:00
|
|
|
[InfluxDB CLI](https://github.com/influxdata/influxdb/blob/master/cmd/influx/main.go).
|