NAME InfluxDB - Client library for InfluxDB INSTALLATION To install this module, run the following commands: perl Build.PL ./Build ./Build test ./Build install CAUTION The JSON write protocol is deprecated as of InfluxDB 0.9.1. It is still present but it will be removed when InfluxDB 1.0 is released. The line protocol is the primary write protocol for InfluxDB 0.9.1+. This InfluxDB module can handle only JSON protocol. If you want to use line protocol, please use InfluxDB::LineProtocol module. SYNOPSIS use InfluxDB; my $ix = InfluxDB->new( host => '127.0.0.1', port => 8086, username => 'scott', password => 'tiger', database => 'test', # ssl => 1, # enable SSL/TLS access # timeout => 5, # set timeout to 5 seconds ); $ix->write_points( data => { name => "cpu", columns => [qw(sys user idle)], points => [ [20, 50, 30], [30, 60, 10], ], }, ) or die "write_points: " . $ix->errstr; my $rs = $ix->query( q => 'select * from cpu', time_precision => 's', ) or die "query: " . $ix->errstr; # $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 This module `InfluxDB` is a client library for InfluxDB <http://influxdb.org>. 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 ssl => Bool (optional) 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, ...], ... ], } The time and any other data fields which should be graphable must be numbers, not text. See "simple scalars" in JSON. 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. delete_points(name => Str) :Bool Delete ALL DATA from series specified by name query(%args:Hash) :ArrayRef 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 } ] } create_continuous_query(q => Str, name => Str) :ArrayRef Create continuous query. $ix->create_continuous_query( q => "select mean(sys) as sys, mean(usr) as usr from cpu group by time(15m)", name => "cpu.15m", ); list_continuous_queries() :ArrayRef List continuous queries. drop_continuous_query(id => Str) :ArrayRef Delete continuous query that has specified id. You can get id of continuous query by list_continuous_queries(). 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. list_series() :ArrayRef[HashRef] List series in current database create_database_user(name => Str, password => Str) :Bool Create a database user on current database. delete_database_user(name => Str) :Bool Delete a database user on current database. update_database_user(name => Str [,password => Str] [,admin => Bool]) :Bool Update a database user on current database. list_database_users() :ArrayRef List all database users on current database. show_database_user(name => Str) :HashRef Show a database user on current database. create_cluster_admin(name => Str, password => Str) :Bool Create a database user on current database. delete_cluster_admin(name => Str) :Bool Delete a database user on current database. update_cluster_admin(name => Str, password => Str) :Bool Update a database user on current database. list_cluster_admins() :ArrayRef List all database users on current database. show_cluster_admin(name => Str) :HashRef Show a database user on current database. 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. errstr() :Str Returns error message if previous query was failed. 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.