idct/symfony-async-monolog-handler 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

idct/symfony-async-monolog-handler

最新稳定版本:0.1

Composer 安装命令:

composer require idct/symfony-async-monolog-handler

包简介

Simple toolchain for Symfony 6+ framework and Monolog which allows sending logs using the symfony/messenger asynchronously.

README 文档

README

Simple toolchain for Symfony 6+ framework and Monolog which allows sending logs using the symfony/messenger asynchronously.

Installation

composer require idct/symfony-async-monolog-handler

Usage

As this is not a bundle, but a library which acts as a toolchain you need to execute three steps before it actually works:

  1. Register the service in your services.yaml:
    monolog.handler.async-stream:
        class: IDCT\Logger\Monolog\Handler\AsyncMessageHandler
        public: false
  1. Choose which real handler should be actually executed. For example if you have:
    file_log:
        type: stream
        # log to var/log/(environment).log
        path: "%kernel.logs_dir%/async-test.log"
        # log *all* messages (debug is lowest level)
        level: debug

in your monolog.yaml then add to services.yaml:

    IDCT\Logger\Messenger\AsyncLogMessageHandler:
        arguments:
            - '@monolog.handler.file_log'
  1. Add you asynchronous channel, for example name it async, then to monolog.yaml add:
monolog:
    channels:
        - async
  1. In monolog.yaml register your async proxy logger:
    async-stream:
        type: 'service'
        id: 'monolog.handler.async-stream'
        channels: ['async']
        level: debug

where id must match the identifier of a service from step 1.

  1. Whenever you want to use your async logger inject it using standard symfony + monolog naming convention which include channel's name:
    public function __construct(protected LoggerInterface $asyncLogger)
    {
        
    }
  1. Register a transport for your async messages in messenger.yaml:
framework:
    messenger:
        transports:
            async: '%env(MESSENGER_TRANSPORT_DSN)%'

        routing:
            # Route your messages to the transports
            'IDCT\Logger\Model\AsyncLogMessage': async
  1. Be sure to set MESSENGER_TRANSPORT_DSN env variable.

  2. Activate symfony/messenger.

  3. Note: Target handler will handle the message even if its channels' list does not match. This can be useful to filter out other messages, for example the target handler may be set to ignore messenger logs:

    file_log:
        type: stream
        # log to var/log/(environment).log
        path: "%kernel.logs_dir%/async-test.log"
        # log *all* messages (debug is lowest level)
        channels: ['!messenger']
        level: debug

Contribution

Any contribution towards better testing is more than welcome. In tests/func you can already find a preconfigured symfony which tests the solution when app:test (TestCommand.php) is executed.

统计信息

  • 总下载量: 720
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 2
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-09-26