Code Monkey home page Code Monkey logo

magento_profiler's Introduction

ecocode Profiler - Magento 1.x Web Profiler

Build Status Coverage Status Code Climate SensioLabsInsight

The ecocode profiler provides a development toolbar for Magento which displays a wide range of metrics and page load data for all the pages of the shop. It gives you direct access to the page's database queries, memory usage, events, requests, layout rendering, translation resolution and many other useful statistics. It is also easily extendable if you need to track additional metrics.

This profiler is based on the awesome Symfony WebProfiler. The concept and code of the WebProfiler have been ported to assist with Magento as much as possible.

Requirements

  • php >= 5.5.9
  • magento < 2

Tested with magento 1.7, 1.8. 1.9

Demo Stores:


Toolbar

Profiler

More Images

Installation

Composer (recommended)

If you have not already configured magento-composer-installer add

"extra": {
   "magento-root-dir": "httpdocs/"
 }

to your composer.json. If your magento root dir is the same directory as the one containing your composer.json use "." as the magento-root-dir

composer require --dev ecocode/magento-profiler

Manually

Download the module and copy the app folder + "dev.php" into your magento root directory

If you install the module manually, it will miss some functionality until you install the dependencies. This is currently only possible via composer as we do need the composer autoloader.

To install the dependencies run the following from your magento root dir or a parent directory:

composer require --dev symfony/debug 3.1
composer require --dev symfony/yaml 3.1
composer require --dev jdorn/sql-formatter 1.2
composer require --dev monolog/monolog 1.11

Magento Connect

ecocode Profiler

Webserver Config

It might be necessary to extend your webserver config to handle "dev.php" correctly. If your experiencing a 404 when you try to access "dev.php"

Nginx:

try adding the following to your nginx config before the php location definition:

location /dev.php/ {
    rewrite / /dev.php;
}

Apache:

nothing to do here, should run out of the box

Usage

The profiler is only enabled if you open your shop via http://myshop.local/dev.php/. The idea is to develop always in dev mode alias "dev.php" and only switch back to "production" from time to time to verify the result.

Features

  • Improved exception handling in dev mode with the symfony/debug. No more checking the log files!
  • Easily extendable, just add a new collector via your configuration

Collectors

  • Request/Response
    • Display of request/response server parameters
  • Memory
    • Display of memory usage
  • Mysql
    • Display of all queries with syntax highlighting and stack traces to locate the origin
    • Queries by context so you can easily determine the origin block
    • Detection of identical queries that can be avoided
    • Metrics for "mysql crud" operations
    • Support for multiple database connections
  • Events
    • Display of all events that have been fired during page load
    • List of all called observers
  • Ajax
    • Recording of ajax calls
  • Customer
    • Display of customer group and tax class
  • Layout
    • Metrics including created and rendered blocks and total rendering time
    • List of layout handlers used
    • List of blocks created but not rendered
    • Call graph including rendering times by block, including and excluding children
  • Translations
    • Display of translations that are defined, missing, invalid or are using a fallback
  • Rewrites
    • Detection of rewrites and rewrite conflicts (credits to magen98-magerun for the detection)
  • Logs
    • Display of all Mage::log calls
  • Models
    • Display of all model load, delete and save calls
    • Detection of "load" calls within loops!
  • Cache
    • Display of current cache configuration including the option to enable/disable and flush from the profiler
    • Display of all cache calls including not-for-cache hits and misses
  • Configuration
    • Base PHP configuration
    • Option to view phpinfo()
    • Basic magento configuration
    • Display of enabled and disabled modules

Security

It is safe to add this module to your own vcs by default. The profiler is only active when you are visiting your page via "dev.php", which is restricted to request from localhost by default.

If you are using a vm you have to allow your host system to access the profiler. This can be done by modify the webserver config or the dev.php itself

Webserver: To allow the access to the profiler you have to set "$_SERVER['ALLOW_PROFILER'] = 1"

Nginx: fastcgi_param ALLOW_PROFILER '1'; Apache: SetEnv ALLOW_PROFILER "1"

TODO

  • Improve docs
  • "how to extend"
  • capture emails
  • performance tab

Mixed

If you get a gateway timeout 503 instead of an error message please try to adjust your nginx config

http {
    ...
    fastcgi_buffers 8 16k;
    fastcgi_buffer_size 32k;
    ...
}

Need help?

Feel free to contact me [email protected]

Thanks to

magento_profiler's People

Contributors

fantus avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.