NAME

Net::Graylog::Client - Client for Graylog2 analysis server

VERSION

version 0.4

SYNOPSIS

 use Net::Graylog::Client ;

 my $log = Net::Graylog::Client->new( url => 'http://graylog.server:12002/gelf' ) ;

 $log->send( message => 'testing', level => 'debug') ;

DESCRIPTION

Send a message to a graylog2 analysis server

You may send any data to a gray log server, but there are some restrictions plus this module adds some defaults.

* There must be a message field * a level field will be interpreted as a syslog level and converted to a number * you can access the original value with the levelstr field * a datetime and timestr field are added, the former is a unix int timestamp, the latter a time string * each message gets a uuid * a server field will be reinterpreseted as a host field, a default of hostname() will be added if needed

NAME

Net::Graylog::Client - Client for Graylog2 analysis server

VERSION

version 0.4

NAME

Net::Graylog::Client

AUTHOR

kevin mulholland

VERSIONS

v0.1 2014/03/19, initial work

Notes

Obviously if you just want oto do this on the command line you can use

curl -XPOST http://graylog2_server:12202/gelf -p0 -d '{"short_message":"Hello there", "host":"example.org", "facility":"test", "_foo":"bar"}'

See Also

Log::Log4perl::Layout::GELF , Net::Sentry::Client

Todo

Investigate HTTP::Async instead of :Furl as it will not block, so we can wait for the response to be received, rather than the timeout to lapse

Public Functions

new

Create a new instance of the logger

my $log = Net::Graylog::Client->new( url => 'http://graylog2_server:12202/gelf') ;

Parameters url the url of the graylog server, of the form http://graylog2_server:12202/gelf timeout, can be a float, default 0.01, Furl seems to wait until the timeout occurs before giving a response, which really cuts into the speed of sending, you may want to make this bigger for non-local servers, ie 1s

send

send a hash of data to the graylog server

my $log = Net::Graylog::Client->new( 'http://graylog2_server:12202/gelf') ;
$log->send( message => 'test message', level => 'info', elapsed = 12.1 )

Any data that is in the hash is passed to the server, though some may be re-interpreted as mentioned in the DESCRIPTION

Parameters hash of data to send

B><Returns> status - true = Sent, false = Failed code - HTTP response code from the graylog server

emerg alert crit error warning notice info debug

short cut to send, setting the syslog level to the name of the method

my $log = Net::Graylog::Client->new( 'http://graylog2_server:12202/gelf') ;
# level = alert
$log->alert( message => 'test message', elapsed = 12.1 )
# level = debug
$log->debug( message => 'test message', elapsed = 12.1 )

Any data that is in the hash is passed to the server, though some may be re-interpreted as mentioned in the DESCRIPTION

The level field is overwritten with the name of the method called

Parameters hash of data to send

B><Returns> status - true = Sent, false = Failed code - HTTP response code from the graylog server

valid_levels

returns a list of the valid syslog levels

valid_facilities

returns a list of the valid syslog facilies

AUTHOR

Kevin Mulholland <moodfarm@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Kevin Mulholland.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.

AUTHOR

Kevin Mulholland <moodfarm@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2017 by James Lavoy.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.