Crear y usar un canal de log en Symfony

por Fran Iglesias

De vez en cuando nos puede interesar disponer de un log específico para una parte concreta de una aplicación. Fundamentalmente lo que pretendemos es aislar esos mensajes para poder analizarlos con facilidad.

Aquí tienes la receta:

Configuración del canal y el handler en monolog

En config.yml, o en el archivo de configuración de enviroment que nos interese (config_dev.yml o config_prod.yml).

monolog:
	channels: ['my_channel', ...]
	handlers:
		my_channel:
			type:         stream
			action_level: info
			path:         "%kernel.logs_dir%/my-channel.log"
			formatter:    monolog.formatter.logstash
			channels:     ['my_channel']

Usar este canal

Cuando necesitemos usar este logger lo pasamos como dependencia. Monolog genera estos servicios automágicamente, así que realmente no hay nada más que hacer:

@monolog.logger.my_channel

Por ejemplo:

    a.service.using.logger:
        class: Vendor\Namespace\ServiceUsingLogger
        arguments:
            - '@monolog.logger.my_channel'

El Type Hinting del logger se debería hacer sobre Psr\Log\LoggerInterface, que es el estándar PSR. Monolog, el logger incluido con Symfony, la implementa.

Ahora, al utilizar este logger, los mensajes se guardarán en el archivo logs/my-channel.log.

Temas

good-practices

refactoring

php

testing

tdd

design-patterns

python

blogtober19

design-principles

tb-list

misc

bdd

legacy

golang

dungeon

ruby

tools

hexagonal

tips

software-design

ddd

books

bbdd

soft-skills

pulpoCon

oop

javascript

api

typescript

sql

ethics

agile

swift

java