IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Symfony PHP Discussion :

Monolog - Ecrire dans un nouveau fichier à chaque fois


Sujet :

Symfony PHP

  1. #1
    Membre confirmé
    Inscrit en
    Janvier 2012
    Messages
    97
    Détails du profil
    Informations forums :
    Inscription : Janvier 2012
    Messages : 97
    Par défaut Monolog - Ecrire dans un nouveau fichier à chaque fois
    Bonjour amis du beau code,

    Je travaille sur un script d'import et je logue les événements dans monologue.
    J'ai définit un channel qui me permet d'avoir mes logs dans la sortie std et dans un fichier log spécifique.

    config.yml
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    monolog:
        channels: ['import_modeles_channel']
        handlers:
            import_modeles:
                channels: ['import_modeles_channel']
                type:     stream
                path:     '%kernel.logs_dir%/import_modeles.log'
            import_modeles_console:
                channels: ['import_modeles_channel']
                type:     console
    Dans la commande je peux logger

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    class ImportModelsCommand extends AbstractCommand
    {
        /** @var Logger  */
        private $logger;  
     
        protected function execute(InputInterface $input, OutputInterface $output)
        {
            /** @var Logger logger */
            $this->logger = $this->getContainer()->get('monolog.logger.import_modeles_channel');
     
            $this->logger->debug('===========');
            $this->logger->debug(date('Y-m-d H:i.s'));
     
          // Tests
            $this->logger->alert('alert');
            $this->logger->critical('critical');
            $this->logger->emergency('emergency');
            $this->logger->error('error');
            $this->logger->warning('warning');
            $this->logger->notice('notice'); // -v
            $this->logger->info('info'); // -vv
            $this->logger->debug('debug'); // -vvv
            // -q RIEN !
     
            // dododooodoodoooo
        }
    }
    Seulement voila. Tous mes logs s'entassent dans '%kernel.logs_dir%/import_modeles.log'

    Et j'aurais bien aimé que mon script génère un nouveau fichier à chaque exécution.
    Et que je puisse récupéré ce fichier à la fin pour l'envoyer par email..

    Comment on fait ça ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $logger->setLogFile($logDir.'import.'.date('Y-m-d_h-i-s').'.log'); // Truc qui n'existe pas ....
    Merci pour votre aide

    Je suis en symfony ~2.7

  2. #2
    Membre extrêmement actif
    Avatar de dukoid
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2012
    Messages
    2 100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 2 100
    Par défaut
    je sais que l'on peut configurer monolog afin qu'arrivait à une taille défini il réécrit depuis le début sur le fichier.

  3. #3
    Membre confirmé
    Inscrit en
    Janvier 2012
    Messages
    97
    Détails du profil
    Informations forums :
    Inscription : Janvier 2012
    Messages : 97
    Par défaut
    Je crois avoir trouvé un solution à mon pb.

    Grâce à la conf de monolog j'ai pu chainer mes handlers : fingers_crossed -> buffer -> swift_mailer
    Comme ça, je reçoit un mail si une erreur critique est levée.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
     
    # https://www.remipoignon.fr/10-symfony-2-configuration-des-logs-monolog
    monolog:
        channels: ['import_modeles_channel']
        handlers:
            main:
                channels: ['!import_modeles_channel']
                type:   stream
                path:   "%kernel.logs_dir%/%kernel.environment%.log"
                level:  info
            console:
                channels: ['!import_modeles_channel']
                type:   console
                bubble: false
     
            import_modeles_stream:
                channels: ['import_modeles_channel']
                type:     rotating_file
                path:     '%kernel.logs_dir%/import_modeles.%kernel.environment%.log'
                max_files: 10
                level: debug
            import_modeles_console:
                channels: ['import_modeles_channel']
                #formatter: my_formatter
                type:     console
                level: debug
            # Ce handler stocke dans un buffer tout les logs qui passe. Lorsqu'un des logs dépasse le niveau minimum requis,
            # il appelle un autre handler avec tous les logs contenus dans son buffer.
            import_modeles_fingers_crossed:
                channels: ['import_modeles_channel']
                type:         fingers_crossed
                action_level: critical
                handler:      import_modeles_buffer
            # Ce handler stocke dans un buffer tout les logs qu'il reçoit
            # puis envoit le buffer à un handler à la fin de l'exécution de la requête.
            import_modeles_buffer:
                channels: ['import_modeles_channel']
                type:    buffer
                handler: import_modeles_swift
            # Ce handle envoit par mail les logs
            import_modeles_swift:
                channels: ['import_modeles_channel']
                type:       swift_mailer
                from_email: error@client.com
                to_email:   moi@patron.fr
                subject:    import_modeles - Une erreur critique est survenue
                level:      info
    Mais j'ai l'impression que les channels ne sont pas pris ne compte...
    En effet dans mon terminal j'ai des log qui ne intéressement pas .

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [2017-11-10 10:09:26] php.INFO: The eZ\Bundle\EzPublishCoreBundle\ApiLoader\RepositoryFactory class extends Symfony\Component\DependencyInjection\ContainerAware that is deprecated since version 2.8, to be removed in 3.0. Use the ContainerAwareTrait instead. {"type":16384,"file":"/var/www/ezpublish5/vendor/symfony/symfony/src/Symfony/Component/Debug/DebugClassLoader.php","line":223,"level":28928,"stack":[{"function":"handleError","class":"Symfony\\Component\\Debug\\ErrorHandler","type":"->"},{"file":"/var/www/ezpublish5/vendor/symfony/symfony/src/Symfony/Component/Debug/DebugClassLoader.php","line":223,"function":"trigger_error"},{"function":"loadClass","class":"Symfony\\Component\\Debug\\DebugClassLoader","type":"->"},{"file":"/var/www/ezpublish5/ezpublish/cache/dev/ezpublishDevDebugProjectContainer.php","line":2036,"function":"spl_autoload_call"},{"file":"/var/www/ezpublish5/vendor/symfony/symfony/src/Symfony/Component/DependencyInjection/Container.php","line":304,"function":"getEzpublish_Api_Repository_FactoryService","class":"ezpublishDevDebugProjectContainer","type":"->"},{"file":"/var/www/ezpublish5/ezpublish/cache/dev/ezpublishDevDebugProjectContainer.php","line":2026,"function":"get","class":"Symfony\\Component\\DependencyInjection\\Container","type":"->"},{"file":"/var/www/ezpublish5/ezpublish/cache/dev/ezpublishDevDebugProjectContainer.php","line":2017,"function":"getEzpublish_Api_InnerRepositoryService","class":"ezpublishDevDebugProjectContainer","type":"->"},{"file":"/var/www/ezpublish5/ezpublish/cache/dev/ezpublishDevDebugProjectContainer.php","line":24326,"function":"{closure}","class":"ezpublishDevDebugProjectContainer","type":"->"},{"file":"/var/www/ezpublish5/ezpublish/cache/dev/ezpublishDevDebugProjectContainer.php","line":24326,"function":"__invoke","class":"Closure","type":"->"},{"file":"/var/www/ezpublish5/vendor/ezsystems/ezpublish-kernel/eZ/Publish/Core/SignalSlot/Repository.php","line":346,"function":"getUserService","class":"eZPublishCoreRepositoryRepository_00000000423964db000000004893f177f7455b74e3ea156ece6c92d7ac2ef930","type":"->"},{"file":"/var/www/ezpublish5/ezpublish/cache/dev/ezpublishDevDebugProjectContainer.php","line":29078,"function":"getUserService","class":"eZ\\Publish\\Core\\SignalSlot\\Repository","type":"->"},{"file":"/var/www/ezpublish5/src/Patron/ToolsBundle/Command/AbstractPatronCommand.php","line":84,"function":"getUserService","class":"eZPublishCoreSignalSlotRepository_00000000423965ce000000004893f177f7455b74e3ea156ece6c92d7ac2ef930","type":"->"},{"file":"/var/www/ezpublish5/src/Client/FrontEndBundle/Command/ImportModelsCommand.php","line":143,"function":"logAsSuperAdmin","class":"Patron\\ToolsBundle\\Command\\AbstractPatronCommand","type":"->"},{"file":"/var/www/ezpublish5/vendor/symfony/symfony/src/Symfony/Component/Console/Command/Command.php","line":264,"function":"execute","class":"Client\\FrontEndBundle\\Command\\ImportModelsCommand","type":"->"},{"file":"/var/www/ezpublish5/vendor/symfony/symfony/src/Symfony/Component/Console/Application.php","line":891,"function":"run","class":"Symfony\\Component\\Console\\Command\\Command","type":"->"},{"file":"/var/www/ezpublish5/vendor/symfony/symfony/src/Symfony/Component/Console/Application.php","line":202,"function":"doRunCommand","class":"Symfony\\Component\\Console\\Application","type":"->"},{"file":"/var/www/ezpublish5/vendor/symfony/symfony/src/Symfony/Bundle/FrameworkBundle/Console/Application.php","line":89,"function":"doRun","class":"Symfony\\Component\\Console\\Application","type":"->"},{"file":"/var/www/ezpublish5/vendor/ezsystems/ezpublish-kernel/eZ/Bundle/EzPublishCoreBundle/Console/Application.php","line":41,"function":"doRun","class":"Symfony\\Bundle\\FrameworkBundle\\Console\\Application","type":"->"},{"file":"/var/www/ezpublish5/vendor/symfony/symfony/src/Symfony/Component/Console/Application.php","line":120,"function":"doRun","class":"eZ\\Bundle\\EzPublishCoreBundle\\Console\\Application","type":"->"},{"file":"/var/www/ezpublish5/ezpublish/console","line":27,"function":"run","class":"Symfony\\Component\\Console\\Application","type":"->"}]}
    Comment je fait pour m'en débarrasser ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
            $handelers = $this->logger->getHandlers();
            foreach($handelers as $k => $handeler) {
                $this->logger->info("$k " . get_class($handeler));
            }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    [2017-11-10 10:39:55] import_modeles_channel.INFO: 0 Symfony\Bridge\Monolog\Handler\DebugHandler  
    [2017-11-10 10:39:55] import_modeles_channel.INFO: 1 Monolog\Handler\RotatingFileHandler  
    [2017-11-10 10:39:55] import_modeles_channel.INFO: 2 Symfony\Bridge\Monolog\Handler\ConsoleHandler  
    [2017-11-10 10:39:55] import_modeles_channel.INFO: 3 Monolog\Handler\FingersCrossedHandler

Discussions similaires

  1. [XL-2007] Copier plusieurs fichiers Excel dans un nouvel onglet à chaque fois
    Par OptionExplicitSu dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 12/06/2012, 17h48
  2. Réponses: 1
    Dernier message: 05/08/2010, 21h37
  3. ecrire dans un nouveau a chaque fois
    Par delta07 dans le forum Débuter avec Java
    Réponses: 9
    Dernier message: 29/06/2010, 10h14
  4. FileWriter ecrire dans un nouveau fichier
    Par Celine76 dans le forum Entrée/Sortie
    Réponses: 3
    Dernier message: 17/09/2008, 18h06
  5. Réponses: 4
    Dernier message: 30/11/2007, 10h23

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo