influxdb/client/README.md

225 lines
5.5 KiB
Markdown
Raw Normal View History

2015-03-27 15:56:00 +00:00
# InfluxDB Client
2015-01-22 22:08:30 +00:00
2015-10-16 00:36:29 +00:00
[![GoDoc](https://godoc.org/github.com/influxdb/influxdb?status.svg)](http://godoc.org/github.com/influxdb/influxdb/client/v2)
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
`import "github.com/influxdb/influxdb/client/v2"`. It is not backwards-compatible.
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
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
**InfluxDB** configuration file.
Thought not necessary for experimentation, you may want to create a new user
and authenticate the connection to your database.
For more information please check out the
[Cluster Admin Docs](http://influxdb.com/docs/v0.9/query_language/database_administration.html).
2015-03-27 22:29:41 +00:00
For the impatient, you can create a new admin user _bubba_ by firing off the
[InfluxDB CLI](https://github.com/influxdb/influxdb/blob/master/cmd/influx/main.go).
```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 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-10-09 02:00:30 +00:00
import
import (
2015-10-09 02:00:30 +00:00
"net/url"
"fmt"
"log"
"os"
"github.com/influxdb/influxdb/client/v2"
)
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
u, _ := url.Parse("http://localhost:8086")
c := client.NewClient(client.Config{
URL: u,
Username: username,
Password: password,
})
// Create a new point batch
bp := client.NewBatchPoints(client.BatchPointsConfig{
Database: MyDB,
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,
2015-03-27 15:56:00 +00:00
}
2015-10-09 02:00:30 +00:00
pt := client.NewPoint("cpu_usage", tags, fields, time.Now())
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_.
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 {
if response.Error() != nil {
return res, response.Error()
2015-03-27 15:56:00 +00:00
}
res = response.Results
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)
}
val := row[1].(string)
log.Printf("[%2d] %s: %s\n", i, t.Format(time.Stamp), val)
2015-03-27 15:56:00 +00:00
}
```
## Go Docs
Please refer to
[http://godoc.org/github.com/influxdb/influxdb/client](http://godoc.org/github.com/influxdb/influxdb/client)
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
2015-03-27 15:56:00 +00:00
[InfluxDB CLI](https://github.com/influxdb/influxdb/blob/master/cmd/influx/main.go).