raven-erlang is an Erlang client for Sentry that integrates with the standard error_logger
module. It also serves as a Lager backend.
Add raven as a dependency to your project, and include the raven-erlang
application in your release.
In rebar.config
:
{deps, [
{raven_erlang, "0.4.3"}
]}.
To start raven_erlang
with your application, add in your myapp.app.src
:
% ...
{applications, [
% ...
raven_erlang
]},
% ...
raven_erlang
is configured using the application environment. This is generally done in app.config or sys.config:
{raven_erlang, [
% One can point `raven_erlang` to a project like this:
{uri, "https://app.getsentry.com"},
{project, "1"},
{public_key, "PUBLIC_KEY"},
{private_key, "PRIVATE_KEY"}, % This is now optional
% ...or just use the DSN:
{dsn, "https://[email protected]/1"},
% {dsn, "https://PUBLIC_KEY:[email protected]/1"}, % If using the private key
% Set to inet6 to use IPv6.
% See `ipfamily` in `httpc:set_options/1` for more information.
% Default value is `inet`.
{ipfamily, inet},
% Set to true in order to install the standard error logger.
% Now all events logged using `error_logger` will be sent to Sentry.
{error_logger, true},
% Customize error logger:
% Default value is `[]`.
{error_logger_config, [
% `warning` or `error`.
% If set to `error`, error logger will ignore warning messages and reports.
% Default value is `warning`.
{level, warning},
% Not all messages that error_logger generates are useful.
% For example, supervisors will always generate an error_report when
% restarting a child, even if it exits with `reason = normal`.
% You can provide a module that implements `raven_error_logger_filter` behavior
% to avoid spamming sentry with issues that are not errors.
% See http://erlang.org/doc/apps/sasl/error_logging.html for more information.
% Default value is `undefined`.
{filter, callback_module}
]}
]}.
At the moment, the raven lager backend shares its configuration with the raven application, and does not allow per-backend configuration.
This adds the raven backend to lager. By default, it configures the raven lager backend to send most metadata that the lager parse transform creates (see Advanced Configuration).
{lager, [
{handlers, [
{raven_lager_backend, info}]}]}
This configuration uses a list [Level :: atom(), MetadataKeys :: [atom()]]
.
MetadataKeys
is a list of atoms that correspond to the metadata to be sent by Raven, should it be included in the lager log message.
The configuration shown here is equivalent to the Simple Configuration.
{lager, [
{handlers, [
{raven_lager_backend,
[info, [pid, file, line, module, function, stacktrace]]}]}]}
To exclude all metadata except pid
:
{lager, [
{handlers, [
{raven_lager_backend, [info, [pid]]}]}]}
You can log directly events to sentry using the raven:capture/2
function, for example:
try erlang:error(badarg)
catch Class:Reason:Stacktrace ->
raven:capture("Test Event", [
{exception, {Class, Reason}},
{stacktrace, Stacktrace},
{extra, [
{pid, self()},
{process_dictionary, erlang:get()}
]}
])
end.