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.

August 29, 2018

Etiquetas: tools   tips  

Temas

good-practices

php

refactoring

testing

tdd

python

blogtober19

design-principles

design-patterns

bdd

misc

legacy

dungeon

tips

tools

golang

ddd

bbdd

soft-skills

ruby

javascript

books

api

sql

oop

ethics

swift

java