Symfony Logging Tutorial
last modified March 3, 2025
Symfony Logging tutorial shows how to use Monolog for logging in Symfony 7.2. We configure Monolog, create custom log channels, and use logging in controllers and services.
Symfony
Symfony is a set of reusable PHP components and a PHP framework for web projects. Symfony was published as free software in 2005. Fabien Potencier is the original author of Symfony. Symfony was heavily inspired by the Spring Framework.
Monolog
Monolog is a logging library for PHP. It is the default logging library used in Symfony. Monolog supports multiple handlers, formatters, and processors, making it highly flexible.
Setting up the project
We start by creating a new Symfony project and installing the necessary dependencies.
$ composer create-project symfony/skeleton symfony-logging "^7.2" $ cd symfony-logging
We create a new Symfony 7.2 project and navigate to the project directory.
$ composer require symfony/monolog-bundle
We install the Monolog bundle, which is already included in Symfony by default. This step ensures the bundle is properly configured.
Configuring Monolog
Monolog is configured in the config/packages/monolog.yaml
file.
We customize the configuration to create custom log channels and handlers.
monolog: channels: - app - security handlers: main: type: stream path: "%kernel.logs_dir%/%kernel.environment%.log" level: debug channels: ["!event"] app: type: stream path: "%kernel.logs_dir%/app.log" level: info channels: ["app"] security: type: stream path: "%kernel.logs_dir%/security.log" level: warning channels: ["security"]
This configuration:
- Creates two custom log channels: app
and security
.
- Logs app
messages to app.log
at the info
level.
- Logs security
messages to security.log
at the warning
level.
- Logs all other messages to the default log file.
Using Logging in a Controller
We create a controller to demonstrate logging.
$ php bin/console make:controller LogController
We generate a LogController
.
<?php declare(strict_types=1); namespace App\Controller; use Psr\Log\LoggerInterface; use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\Routing\Attribute\Route; class LogController extends AbstractController { #[Route('/log', name: 'app_log')] public function index(LoggerInterface $logger): Response { // Log messages using the default logger $logger->debug('This is a debug message.'); $logger->info('This is an info message.'); $logger->warning('This is a warning message.'); $logger->error('This is an error message.'); $logger->critical('This is a critical message.'); // Log messages using custom channels $logger->info('This is an app-specific message.', ['channel' => 'app']); $logger->warning('This is a security-specific message.', ['channel' => 'security']); return new Response('Logging example. Check your log files.'); } }
The LogController
logs messages using the default logger and custom
channels. The LoggerInterface
is injected into the controller.
Using Logging in a Service
We create a service to demonstrate logging in a non-controller context.
<?php declare(strict_types=1); namespace App\Service; use Psr\Log\LoggerInterface; class ExampleService { private LoggerInterface $logger; public function __construct(LoggerInterface $logger) { $this->logger = $logger; } public function doSomething(): void { $this->logger->info('Doing something important in the service.'); } }
The ExampleService
logs a message when the doSomething
method is called.
Testing the Logging
We start the Symfony development server and test the logging functionality.
$ php bin/console server:start
We start the development server.
$ curl localhost:8000/log
We visit the /log
route to trigger logging in the controller.
Check the log files in the var/log/
directory:
- dev.log
: Default log file for all messages.
- app.log
: Custom log file for app
channel messages.
- security.log
: Custom log file for security
channel messages.
Advanced Logging Configuration
Monolog supports advanced configurations, such as: - Logging to different files based on severity. - Sending logs to external services (e.g., Slack, Elasticsearch). - Using processors to add extra data to log records.
monolog: handlers: slack: type: slack token: "xoxb-your-slack-token" channel: "#logs" level: critical
This configuration sends critical logs to a Slack channel.
In this tutorial, we used Monolog for logging in Symfony 7.2. We configured custom log channels, used logging in controllers and services, and explored advanced logging options.
List all Symfony tutorials.