2017 © Pedro Peláez
 

library forp-profiler

A PHP profiler written in C. forp is a lightweight PHP extension which provides the full call stack of your script, with CPU and memory usage, in a plain PHP Array or JSON output.

image

aterrien/forp-profiler

A PHP profiler written in C. forp is a lightweight PHP extension which provides the full call stack of your script, with CPU and memory usage, in a plain PHP Array or JSON output.

  • Sunday, October 12, 2014
  • by aterrien
  • Repository
  • 23 Watchers
  • 315 Stars
  • 127 Installations
  • C
  • 1 Dependents
  • 0 Suggesters
  • 34 Forks
  • 11 Open issues
  • 2 Versions
  • 2 % Grown

The README.md

Introduction

forp is a lightweight PHP extension which provides PHP profile datas., (*1)

Summary of features : - measurement of time and allocated memory for each function - CPU usage - file and line number of the function call - output as Google's Trace Event format - caption of functions - grouping of functions - aliases of functions (useful for anonymous functions), (*2)

forp is non intrusive, it provides PHP annotations to do its work., (*3)

Simple (almost the most complicated) example

Example :, (*4)

<?php
// first thing to do, enable forp profiler
forp_start();

// here, our PHP code we want to profile
function foo()
{
    echo "Hello world !\n";
};

foo();

// stop forp buffering
forp_end();

// get the stack as an array
$profileStack = forp_dump();

print_r($profileStack);

Result :, (*5)

Hello world !
Array
(
    [utime] => 0
    [stime] => 0
    [stack] => Array
        (
            [0] => Array
                (
                    [file] => /home/anthony/phpsrc/php-5.3.8/ext/forp/forp.php
                    [function] => {main}
                    [usec] => 94
                    [pusec] => 6
                    [bytes] => 524
                    [level] => 0
                )

            [1] => Array
                (
                    [file] => /home/anthony/phpsrc/php-5.3.8/ext/forp/forp.php
                    [function] => foo
                    [lineno] => 10
                    [usec] => 9
                    [pusec] => 6
                    [bytes] => 120
                    [level] => 1
                    [parent] => 0
                )

        )

)

Example with annotations

Example :, (*6)

<?php
// first thing to do, enable forp profiler
forp_start();

/**
 * here, our PHP code we want to profile
 * with annotations
 *
 * @ProfileGroup("Test")
 * @ProfileCaption("Foo #1")
 * @ProfileAlias("foo")
 */
function fooWithAnnotations($bar)
{
    return 'Foo ' . $bar;
}

echo "foo = " . fooWithAnnotations("bar") . "\n";

// stop forp buffering
forp_end();

// get the stack as an array
$profileStack = forp_dump();

echo "forp stack = \n";
print_r($profileStack);

Result :, (*7)

foo = Foo bar
forp stack =
Array
(
    [utime] => 0
    [stime] => 0
    [stack] => Array
        (
            [0] => Array
                (
                    [file] => /home/anthony/phpsrc/php-5.3.8/ext/forp/forp.php
                    [function] => {main}
                    [usec] => 113
                    [pusec] => 6
                    [bytes] => 568
                    [level] => 0
                )

            [1] => Array
                (
                    [file] => /home/anthony/phpsrc/php-5.3.8/ext/forp/forp.php
                    [function] => foo
                    [lineno] => 41
                    [groups] => Array
                        (
                            [0] => Test
                        )

                    [caption] => Foo bar
                    [usec] => 39
                    [pusec] => 24
                    [bytes] => 124
                    [level] => 1
                    [parent] => 0
                )

        )

)

php.ini options

  • forp.max_nesting_level : default 50
  • forp.no_internals : default 0

forp PHP API

  • forp_start(flags*) : start forp collector
  • forp_end() : stop forp collector
  • forp_dump() : return stack as flat array
  • forp_print() : display forp stack (SAPI CLI)

forp_start() flags

  • FORP_FLAG_TIME : activate collect of time
  • FORP_FLAG_MEMORY : activate collect of memory usage
  • FORP_FLAG_CPU : retrieve the cpu usage
  • FORP_FLAG_CAPTION : enable caption handler
  • FORP_FLAG_ALIAS : enable alias handler
  • FORP_FLAG_GROUPS : enable groups handler
  • FORP_FLAG_HIGHLIGHT : enable HTML highlighting

forp_dump()

forp_dump() provides an array composed of :, (*8)

  • global fields : utime, stime ...
  • stack : a flat PHP array of stack entries.

Global fields :, (*9)

  • utime : CPU used for user function calls
  • stime : CPU used for system calls

Fields of a stack entry :, (*10)

  • file : file of the call
  • lineno : line number of the call
  • class : Class name
  • function : function name
  • groups : list of associated groups
  • caption : caption of the function
  • usec : function time (without the profiling overhead)
  • pusec : inner profiling time (without executing the function)
  • bytes : memory usage of the function
  • level : depth level from the forp_start call
  • parent : parent index (numeric)

forp_json()

Prints stack as JSON string directly on stdout. This is the fastest method in order to send the stack to a JSON compatible client., (*11)

See forp_dump() for its structure., (*12)

forp_json_google_tracer()

forp_json_google_tracer($filepath) will output stack as Google Trace Event format., (*13)

Usage :, (*14)

// Start profiler
forp_start();

my_complex_function();

// Stop profiler
forp_end();

// Get JSON and save it into file
forp_json_google_tracer("/tmp/output.json");

Then, open Google Chrome or Chromium browser and go to chrome://tracing/. Load the output file and enjoy the result., (*15)

Example output with an existing Drupal website, (*16)

forp_inspect()

forp_inspect('symbol', $symbol) will output a detailed representation of a variable in the forp_dump() result., (*17)

Usage :, (*18)

$var = array(0 => "my", "strkey" => "inspected", 3 => "array");
forp_inspect('var', $var);
print_r(forp_dump());

Result :, (*19)

Array
(
    [utime] => 0
    [stime] => 0
    [inspect] => Array
        (
            [var] => Array
                (
                    [type] => array
                    [size] => 3
                    [value] => Array
                        (
                            [0] => Array
                                (
                                    [type] => string
                                    [value] => my
                                )

                            [strkey] => Array
                                (
                                    [type] => string
                                    [value] => inspected
                                )

                            [3] => Array
                                (
                                    [type] => string
                                    [value] => array
                                )

                        )

                )

        )

)

Available annotations

  • @ProfileGroup

Sets groups that function belongs., (*20)

/**
 * @ProfileGroup("data loading","rendering")
 */
function exec($query) {
    /* ... */
}
  • @ProfileCaption

Adds caption to functions. Caption string may contain references (#) to parameters of the function., (*21)

/**
 * @ProfileCaption("Find row for pk #1")
 */
public function findByPk($pk) {
    /* ... */
}
  • @ProfileAlias

Gives an alias name to a function. Useful for anonymous functions, (*22)

/**
 * @ProfileAlias("MyAnonymousFunction")
 */
$fn = function() {
    /* ... */
}
  • @ProfileHighlight

Adds a frame around output generated by the function., (*23)

/**
 * @ProfileHighlight("1")
 */
function render($datas) {
    /* ... */
}

Demos / UI

forp provides a structure so simple that it's easy to make your own UI., (*24)

But, if you are looking for a user interface with a lot of features, we've made a rich JavaScript client : forp-ui, (*25)

You can see forp in action with the fastest PHP Frameworks : - Beaba (https://github.com/ichiriac/beaba-light) - Slim (https://github.com/codeguy/Slim) - Silex (https://github.com/fabpot/Silex) - Laravel (https://github.com/laravel/laravel), (*26)

groups, (*27)

Build status

Build Status, (*28)

Installation, requirements

Requirements

php5-dev, (*29)

apt-get install php5-dev

Install with Composer

Require forp-PHP-profiler in your project composer.json, (*30)

"require-dev":       {
  "aterrien/forp-profiler" : "~1.1"
},
"repositories" : [
  {
     "type" : "git",
     "url"  : "git@github.com:aterrien/forp-PHP-profiler.git"
  }
]

run Composer install, (*31)

php composer.phar install

compile, (*32)

cd vendor/aterrien/forp-profiler/ext/forp
phpize
./configure
make && make install

and enable forp in your php.ini, (*33)

extension=forp.so

or opt for "old school" installation

Use current release, (*34)

wget https://github.com/aterrien/forp/archive/1.1.0.tar.gz
tar -xvzf 1.1.0.tar.gz
cd 1.1.0/ext/forp

OR dev-master (unstable, at your own risk), (*35)

git clone https://github.com/aterrien/forp-PHP-profiler
cd forp-PHP-profiler/ext/forp

compile, (*36)

phpize
./configure
make && make install

and enable forp in your php.ini, (*37)

extension=forp.so

Tested OS and platforms

Apache

Apache/2.2.16 (Debian), (*38)

PHP 5.3.8 (cli) (built: Sep 25 2012 22:55:18), (*39)

Nginx / php-fpm

nginx version: nginx/1.2.6, (*40)

PHP 5.3.21-1~dotdeb.0 (fpm-fcgi) PHP 5.4.10-1~dotdeb.0 (fpm-fcgi), (*41)

Cloud / AWS

Centos 6.3 (AMI), (*42)

Apache/2.2.15 (Unix), (*43)

PHP 5.4.13 (cli) (built: Mar 15 2013 11:27:51), (*44)

Contributors

Anthony Terrien, Ioan Chiriac, Alexis Okuwa, TOMHTML, (*45)

The Versions

12/10 2014

dev-master

9999999-dev https://github.com/aterrien/forp-PHP-profiler

A PHP profiler written in C. forp is a lightweight PHP extension which provides the full call stack of your script, with CPU and memory usage, in a plain PHP Array or JSON output.

  Sources   Download

MIT

The Requires

  • php >=5.3

 

php benchmark profiler quality

12/10 2014

1.1.0

1.1.0.0 https://github.com/aterrien/forp-PHP-profiler

A PHP profiler written in C. forp is a lightweight PHP extension which provides the full call stack of your script, with CPU and memory usage, in a plain PHP Array or JSON output.

  Sources   Download

MIT

The Requires

  • php >=5.3

 

php benchmark profiler quality