blob: 4945b39b34b3a18869ccddb8d99e696251147882 [file] [log] [blame]
##########################
Profiling Your Application
##########################
The Profiler Class will display benchmark results, queries you have run,
and ``$_POST`` data at the bottom of your pages. This information can be
useful during development in order to help with debugging and
optimization.
Initializing the Class
======================
.. important:: This class does NOT need to be initialized. It is loaded
automatically by the :doc:`Output Library <../libraries/output>`
if profiling is enabled as shown below.
Enabling the Profiler
=====================
To enable the profiler place the following line anywhere within your
:doc:`Controller <controllers>` methods::
$this->output->enable_profiler(TRUE);
When enabled a report will be generated and inserted at the bottom of
your pages.
To disable the profiler you will use::
$this->output->enable_profiler(FALSE);
Setting Benchmark Points
========================
In order for the Profiler to compile and display your benchmark data you
must name your mark points using specific syntax.
Please read the information on setting Benchmark points in the
:doc:`Benchmark Library <../libraries/benchmark>` page.
Enabling and Disabling Profiler Sections
========================================
Each section of Profiler data can be enabled or disabled by setting a
corresponding config variable to TRUE or FALSE. This can be done one of
two ways. First, you can set application wide defaults with the
*application/config/profiler.php* config file.
Example::
$config['config'] = FALSE;
$config['queries'] = FALSE;
In your controllers, you can override the defaults and config file
values by calling the ``set_profiler_sections()`` method of the
:doc:`Output Library <../libraries/output>`::
$sections = array(
'config' => TRUE,
'queries' => TRUE
);
$this->output->set_profiler_sections($sections);
Available sections and the array key used to access them are described
in the table below.
======================= =================================================================== ========
Key Description Default
======================= =================================================================== ========
**benchmarks** Elapsed time of Benchmark points and total execution time TRUE
**config** CodeIgniter Config variables TRUE
**controller_info** The Controller class and method requested TRUE
**get** Any GET data passed in the request TRUE
**http_headers** The HTTP headers for the current request TRUE
**memory_usage** Amount of memory consumed by the current request, in bytes TRUE
**post** Any POST data passed in the request TRUE
**queries** Listing of all database queries executed, including execution time TRUE
**uri_string** The URI of the current request TRUE
**session_data** Data stored in the current session TRUE
**query_toggle_count** The number of queries after which the query block will default to 25
hidden.
======================= =================================================================== ========
.. note:: Disabling the [save_queries](http://ellislab.com/codeigniter/user-guide/database/configuration.html) setting in your database configuration
will also effectively disable profiling for database queries and render
the 'queries' setting above useless. You can optionally override this
setting with `$this->db->save_queries = TRUE;`. Without this setting you
won't be able to view the queries or the [last_query](http://ellislab.com/codeigniter/user-guide/database/helpers.html).