docs/influxdb/content.md

131 lines
4.3 KiB
Markdown

# InfluxDB
InfluxDB is a time series database built from the ground up to handle high write and query loads. InfluxDB is meant to be used as a backing store for any use case involving large amounts of timestamped data, including DevOps monitoring, application metrics, IoT sensor data, and real-time analytics.
[InfluxDB Documentation](https://docs.influxdata.com/influxdb/latest/)
%%LOGO%%
## Using this Image
### Running the container
The InfluxDB image exposes a shared volume under `/var/lib/influxdb`, so you can mount a host directory to that point to access persisted container data. A typical invocation of the container might be:
```console
$ docker run -p 8083:8083 -p 8086:8086 \
-v $PWD:/var/lib/influxdb \
influxdb
```
Modify `$PWD` to the directory where you want to store data associated with the InfluxDB container.
You can also have Docker control the volume mountpoint by using a named volume.
```console
$ docker run -p 8083:8083 -p 8086:8086 \
-v influxdb:/var/lib/influxdb \
influxdb
```
### Exposed Ports
The following ports are important and will be automatically exposed when using `docker run -P`.
- 8083 Admin interface port
- 8086 HTTP API PORT
Other important ports that aren't exposed by default:
- 8091 Meta service port
These two ports do not need to be exposed in a single server configuration.
Find more about API Endpoints & Ports [here](https://docs.influxdata.com/influxdb/latest/concepts/api/).
### Configuration
InfluxDB can be either configured from a config file or using environment variables. To mount a configuration file and use it with the server, you can use this command:
Generate the default configuration file:
```console
$ docker run --rm influxdb influxd config > influxdb.conf
```
Modify the default configuration, which will now be available under `$PWD`. Then start the InfluxDB container.
```console
$ docker run -p 8083:8083 -p 8086:8086 \
-v $PWD/influxdb.conf:/etc/influxdb/influxdb.conf:ro \
influxdb -config /etc/influxdb/influxdb.conf
```
Modify `$PWD` to the directory where you want to store the configuration file.
For environment variables, the format is `INFLUXDB_$SECTION_$NAME`. All dashes (`-`) are replaced with underscores (`_`). If the variable isn't in a section, then omit that part.
Examples:
```console
INFLUXDB_REPORTING_DISABLED=true
INFLUXDB_META_DIR=/path/to/metadir
INFLUXDB_DATA_QUERY_LOG_ENABLED=false
```
Find more about configuring InfluxDB [here](https://docs.influxdata.com/influxdb/latest/introduction/installation/)
### Graphite
InfluxDB supports the Graphite line protocol, but the service and ports are not exposed by default. To run InfluxDB with Graphite support enabled, you can either use a configuration file or set the appropriate environment variables. Run InfluxDB with the default Graphite configuration:
```console
docker run -p 8083:8083 -p 8086:8086 \
-e INFLUXDB_GRAPHITE_ENABLED=true \
influxdb
```
See the [README on GitHub](https://github.com/influxdata/influxdb/blob/master/services/graphite/README.md) for more detailed documentation to set up the Graphite service. In order to take advantage of graphite templates, you should use a configuration file by outputting a default configuration file using the steps above and modifying the `[[graphite]]` section.
### HTTP API
Creating a DB named mydb:
```console
$ curl -G http://localhost:8086/query --data-urlencode "q=CREATE DATABASE mydb"
```
Inserting into the DB:
```console
$ curl -i -XPOST 'http://localhost:8086/write?db=mydb' --data-binary 'cpu_load_short,host=server01,region=us-west value=0.64 1434055562000000000'
```
Read more about this in the [official documentation](https://docs.influxdata.com/influxdb/latest/guides/writing_data/)
### CLI / SHELL
Start the container:
```console
$ docker run --name=influxdb -d -p 8083:8083 -p 8086:8086 influxdb
```
Run the influx client in another container:
```console
$ docker run --rm --link=influxdb -it influxdb influx -host influxdb
```
Alternatively, jump directly into the container:
```console
$ docker exec -it influxdb influx
```
### Web Administrator Interface
Navigate to [localhost:8083](http://localhost:8083) with your browser while running the container.
See more about using the web admin [here](https://docs.influxdata.com/influxdb/latest/tools/web_admin/).