The talking bit

A blog about programming, mainly PHP, and maybe other things


Project maintained by franiglesias Hosted on GitHub Pages — Theme by mattgraham

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

php good-practices blogtober19 testing refactoring tdd design-principles legacy misc design-patterns bdd tips python ddd tools soft-skills bbdd api sql ethics testing, swift javascript