InfluxDB (Database service)

InfluxDB is a time series database optimized for high-write-volume use cases such as logs, sensor data, and real-time analytics. It exposes an HTTP API for client interaction.

See the InfluxDB documentation for more information.

Supported versions

  • 1.2
  • 1.3
  • 1.7


The format exposed in the $PLATFORM_RELATIONSHIPS environment variable:

    "service": "influxdb",
    "ip": "",
    "hostname": "",
    "cluster": "rjify4yjcwxaa-master-7rqtwti",
    "host": "influxdb.internal",
    "rel": "influxdb",
    "scheme": "http",
    "type": "influxdb:1.7",
    "port": 8086

Usage example

In your .platform/services.yaml:

    type: influxdb:1.7
    disk: 256

In your

    influxtimedb: "timedb:influxdb"

You can then use the service in a configuration file of your application with something like:

// This assumes a fictional application with an array named $settings.
    $relationships = json_decode(base64_decode($relationships), TRUE);

    // For a relationship named 'influxtimedb' referring to one endpoint.
    if (!empty($relationships['influxtimedb'])) {
        foreach ($relationships['influxtimedb'] as $endpoint) {
            $settings['influxdb_host'] = $endpoint['host'];
            $settings['influxdb_port'] = $endpoint['port'];

Exporting data

InfluxDB includes its own export mechanism. To gain access to the server from your local machine open an SSH tunnel with the CLI:

platform tunnel:open

That will open an SSH tunnel to all services on your current environment, and produce output something like the following:

SSH tunnel opened on port 30000 to relationship: influxtimedb

The port may vary in your case. Then, simply run InfluxDB's export commands as desired.

influx_inspect export -compress