Version | Build Status | Code Coverage |
---|---|---|
master |
||
develop |
The Sentry Monolog Adapter is a Symfony bundle designed to enhance and provide granular control over logging to Sentry. It is particularly powerful for applications that use the Symfony Messenger component, allowing you to implement intelligent logging strategies to avoid log floods and focus on critical errors.
- Advanced Log Processing: Utilizes a decorator for Monolog's Sentry handler to process and enrich log records before they are sent.
- Customizable Processors: Add your own processors to include or modify contextual data, with a built-in
ExceptionProcessor
to get you started. - Intelligent Messenger Logging: A dedicated middleware for the Symfony Messenger component that allows you to control which messages are logged based on flexible strategies.
- Built-in Logging Strategies: A suite of strategies is provided out-of-the-box, including:
LogAllFailedStrategy
: Only logs messages that fail.LogAfterPositionStrategy
: Logs messages after a specific number of retries.ArithmeticProgressionStrategy
: Logs based on an arithmetic sequence of retry attempts.- And several others to fit your needs.
- Modern and Compatible: Built for PHP 8.1+ and compatible with
sentry/sentry-symfony
v5.
Open a command console, enter your project directory and execute:
$ composer require macpaw/sentry-monolog-adapter
Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:
$ composer require macpaw/sentry-monolog-adapter
This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.
Then, enable the bundle by adding it to the list of registered bundles
in the app/AppKernel.php
file of your project:
<?php
// app/AppKernel.php
// ...
class AppKernel extends Kernel
{
public function registerBundles()
{
$bundles = array(
// ...
SentryMonologAdapter\SentryMonologAdapterBundle::class => ['all' => true],
);
// ...
}
// ...
}
config/packages/sentry_monolog_adapter.yaml
Configurating logging strategies of MessengerLoggingMiddleware - all strategies you can see here.
sentry_monolog_adapter:
messenger_logging_middleware:
logging_strategies: // array of logging strategies
- id: sentry_monolog_adapter.log_after_position_strategy
options:
position: 3
- id: sentry_monolog_adapter.log_all_failed_strategy
config/packages/monolog.yaml
sentry:
type: service
id: sentry_monolog_adapter.monolog_handler_decorator
config/packages/messenger.yaml
middleware:
....
- sentry_monolog_adapter.messenger_logging_middleware
....
It is possible to add preprocessors for putting your parameters to the additional data. Our library provides a basic implementation, but at any time we can replace it with our own implementation
sentry_monolog_adapter:
monolog_handler_decorator:
processors:
- sentry_monolog_adapter.exception_processor