NAME InfluxDB - Client library for InfluxDB SYNOPSIS use InfluxDB; my $ix = InfluxDB->new( host => '127.0.0.1', port => 8086, username => 'scott', password => 'tiger', database => 'test', ); $ix->write_points( data => { name => "cpu", columns => [qw(sys user idle)], points => [ [20, 50, 30], [30, 60, 10], ], }, ) or die "write_points: " . $ix->status->{status_line}; my $rs = $ix->query( q => 'select * from cpu', time_precision => 's', ) or die "query: " . $ix->status->{status_line}; # $rs is ArrayRef[HashRef]: # [ # { # columns => ["time","sequence_number","idle","sys","user"], # name => "cpu", # points => [ # ["1391743908",6500001,10,30,60], # ["1391743908",6490001,30,20,50], # ], # }, # ] my $hrs = $ix->as_hash($rs); # or InfluxDB->as_hash($rs); # convert into HashRef for convenience # { # cpu => [ # { # idle => 10, # seqnum => 6500001, # sys => 30, # time => "1391743908", # user => 60 # }, # { # idle => 30, # seqnum => 6490001, # sys => 20, # time => "1391743908", # user => 50 # } # ] # } DESCRIPTION InfluxDB is a client library for InfluxDB <<http://influxdb.org>>. **************************** CAUTION **************************** InfluxDB that is a time series database is still in development status, so this module is also alpha state. Any API will change without notice. ***************************************************************** METHODS Class Methods new(%args:Hash) :InfluxDB Creates and returns a new InfluxDB client instance. Dies on errors. %args is following: host => Str port => Int (default: 8086) username => Str password => Str database => Str timeout => Int (default: 120) debug => Bool (optional) Instance Methods write_points(%args:Hash) :Bool Write to multiple time series names. data => ArrayRef[HashRef] | HashRef HashRef like following: { name => "name_of_series", columns => ["col1", "col2", ...], points => [ [10.0, 20.0, ...], [10.9, 21.3, ...], ... ], } time_precision => "s" | "m" | "u" (optional) The precision timestamps should come back in. Valid options are s for seconds, m for milliseconds, and u for microseconds. query(%args:Hash) :Bool q => Str The InfluxDB query language, see: <http://influxdb.org/docs/query_language/> time_precision => "s" | "m" | "u" (optional) The precision timestamps should come back in. Valid options are s for seconds, m for milliseconds, and u for microseconds. chunked => Bool (default: 0) Chunked response. as_hash($result:ArrayRef[HashRef]) :HashRef Utility instance/class method for handling result of query. Takes result of "query()"(ArrayRef) and convert into following HashRef. { cpu => [ { idle => 10, seqnum => 6500001, sys => 30, time => "1391743908", user => 60 }, { idle => 30, seqnum => 6490001, sys => 20, time => "1391743908", user => 50 } ] } switch_database(database => Str) :Bool Switch to another database. switch_user(username => Str, password => Str) :Bool Change your user-context. create_database(database => Str) :Bool Create database. Requires cluster-admin privileges. list_database() :ArrayRef[HashRef] List database. Requires cluster-admin privileges. [ { name => "databasename", replicationFactor => 1 }, ... ] delete_database(database => Str) :Bool Delete database. Requires cluster-admin privileges. status() :HashRef Returns status of previous request, as following hash: code => Int HTTP status code. message => Str HTTP status message. status_line => Str HTTP status line (code . " " . message). content => Str Response body. host() :Str Returns hostname of InfluxDB server. port() :Str Returns port number of InfluxDB server. username() :Str Returns current user name. database() :Str Returns current database name. ENVIRONMENT VARIABLES IX_DEBUG Print debug messages to STDERR. AUTHOR HIROSE Masaaki <hirose31@gmail.com> REPOSITORY <https://github.com/hirose31/p5-InfluxDB> git clone https://github.com/hirose31/p5-InfluxDB.git patches and collaborators are welcome. SEE ALSO <http://influxdb.org> COPYRIGHT Copyright HIROSE Masaaki LICENSE This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.