Skip to content

enlitepro/enlite-slow-log

Repository files navigation

Enlite slow log

Log slow pages in Zend Framework 2

INSTALL

The recommended way to install is through composer.

{
    "require": {
        "enlitepro/enlite-slow-log": "~1.0.0"
    }
}

USAGE

Add EnliteSlowLog to your config/application.config.php to enable module.

Create enlite-slow-log.global.php in config/autoload with configuration

<?php

return array(
    'EnliteSlowLog' => array(
        // service manager alias
        // accept zend logger and PSR-3 logger like monolog
        'logger' => 'EnliteMonologService',
        // in milliseconds
        'threshold' => 1000
    )
);

Configure with Zend\Log

// prepare logger via Zend\Log\LoggerAbstractServiceFactory
// in config/autoload/log.global.php
'log' => array(
    'MySlowLog' => array(
        'writers' => array(
            array(
                'name' => 'Zend\Log\Writer\Stream',
                'options' => array(
                    "stream" => "data/slow.log"
                )
            )
        )
    )
),

// in config/autoload/enlite-slow-log.global.php
'EnliteSlowLog' => array(
    'logger' => 'MySlowLog',
    'threshold' => 1000
),

Log will be written to data/slow.log

Configure with EnliteMonolog

Install EnliteMonolog

// in config/autoload/enlite-monolog.global.php
'EnliteMonolog' => array(
    'MySlowLog' => array(
        'name' => 'SlowLog', // will be output to log
        'handlers' => array(
            'default' => array(
                'name' => 'Monolog\Handler\StreamHandler',
                'args' => array(
                    'path' => 'data/slow.log'
                )
            )
        )
    )
),

// in config/autoload/enlite-slow-log.global.php
'EnliteSlowLog' => array(
    'logger' => 'MySlowLog',
    'threshold' => 1000
)

Configure custom logger

// in Module.php
public function getServiceConfig()
{
    return array(
        'factories' => array(
            'MySlowLogger' => function(){
                $logger = new \Zend\Log\Logger();
                $writer = new \Zend\Log\Writer\Stream("data/slow.log");
                $logger->addWriter($writer);

                return $writer;
            }
        )
    );
}

// in enlite-slow-log.global.php

'EnliteSlowLog' => array(
    'logger' => 'MySlowLogger',
    'threshold' => 1000
)

Log will be written to data/slow.log