Go to file
Jon Seymour 9491846047 models: improve handling of points with empty field names or with no fields
Influx does not support fields with empty names or points
with no fields.

NewPoint is changed to validate that all field names are non-empty.

AddField is removed because we now require that all fields are
specified on construction.

NewPointFromByte is changed to return an error if a unmarshaled
binary point does not have any fields.

newFieldsFromBinary is changed to prevent an infinite loop that
can arise while attempting to parse corrupt binary point data.

TestNewPointsWithBytesWithCorruptData is changed to reflect the
change in the behaviour of NewPointFromByte.

Signed-off-by: Jon Seymour <jon@wildducktheories.com>
2016-02-20 22:22:26 +11:00
.hooks Use go1.4.3 2016-01-10 16:43:31 -07:00
client It _is_ recommended to send data with a timestamp 2015-12-15 18:33:36 -06:00
cluster Don't parse points twice when receiving remote writes 2016-01-27 14:24:56 -07:00
cmd Merge pull request #5515 from influxdata/jw-config 2016-02-02 13:26:11 -07:00
etc Remove top-level dir config option 2016-02-02 13:03:44 -07:00
importer Importer fixes. fixes #4650 #4651 2015-11-03 16:26:17 -06:00
influxql Merge pull request #5403 from influxdata/meta-service2 2016-01-22 20:06:51 -05:00
models models: improve handling of points with empty field names or with no fields 2016-02-20 22:22:26 +11:00
monitor Fix monitor tests 2016-01-21 15:28:34 -05:00
pkg Correctly name pkg README 2015-12-17 11:24:58 -08:00
scripts Added support for Amazon Linux to installation scripts. 2016-02-04 09:17:59 -06:00
services fix #5505: clear authCache when pwd changes 2016-02-02 17:51:21 -05:00
shared/admin Merge pull request #4286 from ivanyu/master 2015-12-14 13:57:19 -08:00
statik Nightly is now 0.10.0 2015-12-08 10:00:57 -08:00
stress Change db flag message 2015-12-29 13:12:05 -08:00
tcp fix data race in services/meta tests 2016-01-21 15:28:33 -05:00
tests Update test scripts to use measurement for JSON 2015-06-02 20:44:11 -06:00
toml reneable toml test TestConfig_Encode fixes #4691 2015-11-05 18:40:42 -06:00
tsdb fix vet error 2016-02-01 15:33:54 -06:00
uuid Changes to make the uuid subpakage golint-able. 2015-09-18 22:47:15 -05:00
.dockerignore decouple circleci from tests using docker 2015-12-14 16:39:39 -07:00
.gitignore b*1 to tsm1 shard converter 2015-12-29 15:31:07 -05:00
CHANGELOG.md fix #5505: clear authCache when pwd changes 2016-02-02 17:51:21 -05:00
CODING_GUIDELINES.md Add initial coding guidelines 2015-11-24 08:59:39 -08:00
CONTRIBUTING.md Use go1.4.3 2016-01-10 16:43:31 -07:00
DOCKER.md Fix docker HTTP port example 2015-08-19 12:18:56 -06:00
Dockerfile Add instructions for building a minimal docker image 2015-08-07 14:27:33 -06:00
Dockerfile_build_ubuntu32 Use go1.4.3 2016-01-10 16:43:31 -07:00
Dockerfile_build_ubuntu64 Use go1.4.3 2016-01-10 16:43:31 -07:00
Dockerfile_build_ubuntu64_git Use go1.4.3 2016-01-10 16:43:31 -07:00
Dockerfile_test_ubuntu32 Use go1.4.3 2016-01-10 16:43:31 -07:00
LICENSE update the year in the LICENSE file 2015-01-05 21:35:28 -08:00
LICENSE_OF_DEPENDENCIES.md updating Golang crypto 2015-11-04 15:30:32 -08:00
Makefile tsm1 meta lint 2015-10-15 15:03:10 -06:00
QUERIES.md Update QUERIES.md 2015-10-27 23:02:18 -07:00
README.md Update packaing and build for new github org 2016-01-04 15:47:04 -08:00
build-docker.sh refactor remote mapping 2015-08-22 10:16:41 -04:00
build.py A few updates to build.py: 2016-02-04 09:16:32 -06:00
build.sh decouple circleci from tests using docker 2015-12-14 16:39:39 -07:00
circle-test.sh add docker rm flag so circleci can disable deletion of containers 2016-02-02 15:18:58 -07:00
circle.yml decouple circleci from tests using docker 2015-12-14 16:39:39 -07:00
errors.go tsm1 meta lint 2015-10-15 15:03:10 -06:00
gobuild.sh make tip container usable for any git revision, add go1.6beta1 test 2015-12-16 15:28:35 -07:00
influxvar.go Fix minor typo in comment 2015-09-07 22:04:37 -07:00
nightly.sh Update packaing and build for new github org 2016-01-04 15:47:04 -08:00
node.go Remove top-level dir config option 2016-02-02 13:03:44 -07:00
package.sh Use go1.4.3 2016-01-10 16:43:31 -07:00
test.sh add docker rm flag so circleci can disable deletion of containers 2016-02-02 15:18:58 -07:00

README.md

InfluxDB Circle CI

An Open-Source, Distributed, Time Series Database

InfluxDB v0.9.0 is now out. Going forward, the 0.9.x series of releases will not make breaking API changes or breaking changes to the underlying data storage. However, 0.9.x clustering should be considered an alpha release.

InfluxDB is an open source distributed time series database with no external dependencies. It's useful for recording metrics, events, and performing analytics.

Features

  • Built-in HTTP API so you don't have to write any server side code to get up and running.
  • Data can be tagged, allowing very flexible querying.
  • SQL-like query language.
  • Clustering is supported out of the box, so that you can scale horizontally to handle your data.
  • Simple to install and manage, and fast to get data in and out.
  • It aims to answer queries in real-time. That means every data point is indexed as it comes in and is immediately available in queries that should return in < 100ms.

Getting Started

The following directions apply only to the 0.9.x series or building from the source on master.

Building

You don't need to build the project to use it - you can use any of our pre-built packages to install InfluxDB. That's the recommended way to get it running. However, if you want to contribute to the core of InfluxDB, you'll need to build. For those adventurous enough, you can follow along on our docs.

Starting InfluxDB

  • service influxdb start if you have installed InfluxDB using an official Debian or RPM package.
  • systemctl start influxdb if you have installed InfluxDB using an official Debian or RPM package, and are running a distro with systemd. For example, Ubuntu 15 or later.
  • $GOPATH/bin/influxd if you have built InfluxDB from source.

Creating your first database

curl -G 'http://localhost:8086/query' --data-urlencode "q=CREATE DATABASE mydb"

Insert some data

curl -XPOST 'http://localhost:8086/write?db=mydb' \
-d 'cpu,host=server01,region=uswest load=42 1434055562000000000'

curl -XPOST 'http://localhost:8086/write?db=mydb' \
-d 'cpu,host=server02,region=uswest load=78 1434055562000000000'

curl -XPOST 'http://localhost:8086/write?db=mydb' \
-d 'cpu,host=server03,region=useast load=15.4 1434055562000000000'

Query for the data

curl -G http://localhost:8086/query?pretty=true --data-urlencode "db=mydb" \
--data-urlencode "q=SELECT * FROM cpu WHERE host='server01' AND time < now() - 1d"

Analyze the data

curl -G http://localhost:8086/query?pretty=true --data-urlencode "db=mydb" \
--data-urlencode "q=SELECT mean(load) FROM cpu WHERE region='uswest'"

Looking for Support?

InfluxDB has technical support subscriptions to help your project succeed. We offer Developer Support for organizations in active development and Production Support for companies requiring the best response times and SLAs on technical fixes. Visit our support page to learn which subscription is right for you, or contact sales@influxdb.com for a quote.