pdffiller / laravel-influx-provider by klay

Service provider to set up and use InfluxDB SDK in Laravel 5
6,225
18
15
Package Data
Maintainer Username: klay
Maintainer Contact: anbalandin@gmail.com (Anton Balandin)
Package Create Date: 2016-04-29
Package Last Update: 2019-12-03
Language: PHP
License: MIT
Last Refreshed: 2024-11-22 15:01:35
Package Statistics
Total Downloads: 6,225
Monthly Downloads: 18
Daily Downloads: 0
Total Stars: 18
Total Watchers: 15
Total Forks: 9
Total Open Issues: 0

Laravel InfluxDB provider

A minimal service provider to set up and use InfluxDB SDK in Laravel 5

Installation

  • Add a line to the require section of composer.json and execute $ composer install
"require": {
//  ...
    "pdffiller/laravel-influx-provider": "^1.6"
}
  • Add these lines to config/app.php
'providers' => [
//  ...
    Pdffiller\LaravelInfluxProvider\InfluxDBServiceProvider::class,
]


'aliases' => [
// ...
    'Influx' => Pdffiller\LaravelInfluxProvider\InfluxDBFacade::class,
]

  • Define env variables to connect to InfluxDB
LARAVEL_INFLUX_PROVIDER_PROTOCOL=http
LARAVEL_INFLUX_PROVIDER_USER=some_user
LARAVEL_INFLUX_PROVIDER_PASSWORD=some_password
LARAVEL_INFLUX_PROVIDER_HOST=host
LARAVEL_INFLUX_PROVIDER_PORT=8086
LARAVEL_INFLUX_PROVIDER_DATABASE=database_name
LARAVEL_INFLUX_PROVIDER_VERIFY_SSL=false
LARAVEL_INFLUX_PROVIDER_TIMEOUT=0
LARAVEL_INFLUX_PROVIDER_CONNECT_TIMEOUT=0

How to use

$client = new \Influx;
$data   = $client::query('SELECT * from "data" ORDER BY time DESC LIMIT 1');
$point = [
    new \InfluxDB\Point(
        'name' => 'some_name',
        'value' => 1, // some value for some_name
        'tags' => [
            // array of string values
        ],
        'fields' => [
            // array of numeric values
        ],
        'timestamp' => exec('date +%s%N')  // timestamp in nanoseconds on Linux ONLY
    )
];
try {
    Influx::writePoints($point);
} catch (\InfluxDB\Exception $e) {
    // something is wrong, track this
}

Also you can send data to another database like this:

Influx::selectDB($dbName)->writePoints($point);