Skip to content

Commit

Permalink
influxdb: improve documentation
Browse files Browse the repository at this point in the history
* alias for accessing the influx shell
* how to change configuration settings
* how to do maintainance on container refusing to start
  • Loading branch information
ukkopahis committed Apr 20, 2022
1 parent 9cc8533 commit b98b271
Showing 1 changed file with 82 additions and 11 deletions.
93 changes: 82 additions & 11 deletions docs/Containers/InfluxDB.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,16 +14,53 @@ To connect use:
| URL (from other services) | http://influxdb:8086 |
| URL (on the host machine) | http://localhost:8086 |

Open the CLI interactive shell by:

``` console
$ docker exec -it influxdb influx
```

## References
- [Docker](https://hub.docker.com/_/influxdb)
- [Website](https://www.influxdata.com/)
- [InfluxDB documentation](https://docs.influxdata.com/influxdb/v1.8/)
- [Using the InfluxDB image (Docker Hub)](https://hub.docker.com/_/influxdb)

## Configuration

Most
[settings](https://docs.influxdata.com/influxdb/v1.8/administration/config) can
be set using environment variables in `~IOTstack/docker-compose.yml`. These
will override settings in the configuration file.

For instance, if you plan on having lots of data or tags, to prevent influxdb
from using up all your RAM for indexes, add:
```yaml
- INFLUXDB_DATA_INDEX_VERSION=tsi1
```
It's not recommended that you change the `influxdb.conf`-configuration file.
But if you absolutely need to, you should to export it as a persistent volume
(otherwise every update/recreate will undo your changes). To do this, edit
`docker-compose.yml` and under influxdb's `volumes:` add:

```yaml
- ./volumes/influxdb/config:/etc/influxdb
```
And then recreate the container: `docker-compose up -d influxdb`

## Setup

To install helper alias `influx` that opens the influx console and displays
times as human-readable:

``` console
$ echo "alias iotstack_influx='docker-compose -f ~/IOTstack/docker-compose.yml \
exec influxdb influx -precision=rfc3339'" >> ~/.profile
$ source ~/.profile
```

To access the influx console, show current databases and database measurements:
```
pi@raspberrypi:~/IOTstack $ docker-compose exec influxdb bash
root@6bca535a945f:/# influx
pi@raspberrypi:~ $ iotstack_influx
Connected to http://localhost:8086 version 1.8.10
InfluxDB shell version: 1.8.10
> show databases
Expand All @@ -49,6 +86,9 @@ To create a new database and set a limited retention policy, here for instance
any data older than 52 weeks is deleted:

```
$ iotstack_influx
Connected to http://localhost:8086 version 1.8.10
InfluxDB shell version: 1.8.10
> create database mydb
> show retention policies on mydb
name duration shardGroupDuration replicaN default
Expand Down Expand Up @@ -79,24 +119,55 @@ on your card. The goal is to avoid writing lots of small changes targeting the
same physical blocks. Here are some tips to mitigate SD-card wear:

* Don't use short retention policies. This may mask heavy disk IO without
increasing disk space usage. Depending on the file system used, new data may
be written to the same flash blocks that were freed by expiration, wearing
them out.
increasing disk space usage. Depending on the flash card and file system
used, new data may be re-written to the same blocks that were freed by the
expiration, wearing them out.
* Take care not to add measurements too often. If possible no more often than
once a minute. Add all measurements in one operation.
once a minute. Add all measurements in one operation. Even a small write
will physically write a whole new block and erase the previously used block.
* Adding measurements directly to Influxdb will cause a write on every
operation. If your client code can't aggregate multiple measurements into one
write, consider routing them via Telegraf. It has the
`flush_interval`-option, which will combine the measurements into one write.
* All InfluxDB queries are logged by default and logs are written to the
SD-card. To disable this, add to docker-compose.yml, next to the other
SD-card. To disable this, add into docker-compose.yml, next to the other
INFLUXDB_\* entries:
```
```yaml
- INFLUXDB_DATA_QUERY_LOG_ENABLED=false
- INFLUXDB_HTTP_LOG_ENABLED=false
```
This is especially important if you plan on having Grafana or Chronograf
displaying up-to-date data on a dashboard.
displaying up-to-date data on a dashboard, making queries all the time.

## Maintanance when container refuses to start

Sometimes you need start the container without starting influxdb to access
its maintenance tools. Usually when influx crashes on startup.

Add a new line below `influxdb:` to your docker-compose.yml:
```yaml
influxdb:
entrypoint: sleep infinity
```

Recreate the container using the new entrypoint:
``` console
pi@raspberrypi:~/IOTstack $ docker-compose up -d influxdb
Recreating influxdb ... done
```

Now it should start and you can get a shell to poke around and try the
influx_inspect:
``` console
$ docker exec -it influxdb bash
root@5ecc8536174f:/# influx_inspect
Usage: influx_inspect [[command] [arguments]]
```
You may need to do `apt-get update` and `apt-get install` some tools you need.
The container is pretty bare-bones by default.

Of course remove the custom entrypoint and "up -d" again to test if your fixes
worked.

## Old-menu branch
The credentials and default database name for influxdb are stored in the file called influxdb/influx.env . The default username and password is set to "nodered" for both. It is HIGHLY recommended that you change them. The environment file contains several commented out options allowing you to set several access options such as default admin user credentials as well as the default database name. Any change to the environment file will require a restart of the service.
Expand Down

0 comments on commit b98b271

Please sign in to comment.