NAME Riemann::Client - A Perl client for the Riemann event system SYNOPSIS use Riemann::Client; # host and port are optional my $r = Riemann::Client->new( host => 'localhost', port => 5555, ); # send a simple event $r->send({service => 'testing', metric => 2.5}); # Or a more complex one $r->send({ host => 'web3', # defaults to Net::Domain::hostfqdn() service => 'api latency', state => 'warn', metric => 63.5, time => time() - 10, # defaults to time() description => '63.5 milliseconds per request', }); # send several events at once my @events = ( { service => 'service1', ... }, { service => 'service2', ... }, ); $r->send(@events); # Get all the states from the server my $res = $r->query('true'); # Or specific states matching a query $res = $r->query('host =~ "%.dc1" and state = "critical"'); DESCRIPTION Riemann::Client sends events and/or queries to a Riemann server. METHODS new Returns an instance of the Riemann::Client. These are the optional arguments accepted: host The Riemann server. Defaults to "localhost" port Port where the Riemann server is listening. Defaults to 5555 proto By default Riemann::Client will use TCP to communicate over the network. You can force the usage of UDP setting this argument to 'udp'. UDP datagrams have a maximum size of 16384 bytes by Riemann's default. If you force the usage of UDP and try to send a larger message, an exception will be raised. send Accepts a list of events (as hashrefs) and sends them over the wire to the server. query Accepts a string and returns a message. MESSAGE SPECS This is the specification of the messages in Google::ProtocolBuffers format: message State { optional int64 time = 1; optional string state = 2; optional string service = 3; optional string host = 4; optional string description = 5; optional bool once = 6; repeated string tags = 7; optional float ttl = 8; } message Event { optional int64 time = 1; optional string state = 2; optional string service = 3; optional string host = 4; optional string description = 5; repeated string tags = 7; optional float ttl = 8; repeated Attribute attributes = 9; optional sint64 metric_sint64 = 13; optional double metric_d = 14; optional float metric_f = 15; } message Query { optional string string = 1; } message Msg { optional bool ok = 2; optional string error = 3; repeated State states = 4; optional Query query = 5; repeated Event events = 6; } message Attribute { required string key = 1; optional string value = 2; } SEE ALSO * All About Riemann <http://aphyr.github.com/riemann/> * Ruby client <https://github.com/aphyr/riemann-ruby-client> AUTHOR * Miquel Ruiz <mruiz@cpan.org> COPYRIGHT AND LICENSE This software is copyright (c) 2012 by Miquel Ruiz. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.