doc/book/pyramid/profiling.rst
changeset 11631 faf279e33298
parent 11537 caf268942436
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/doc/book/pyramid/profiling.rst	Mon Sep 26 14:52:12 2016 +0200
@@ -0,0 +1,52 @@
+.. _profiling:
+
+Profiling
+=========
+
+Profiling of requests by the pyramid debug toolbar can be a little restrictive
+when a specific url needs thin profiling that includes the whole pyramid
+dispatch.
+
+Pyramid CubicWeb provides facilities to profile requests as a
+:func:`wsgi middleware <cubicweb.pyramid.profile.wsgi_profile>`, and a few
+views that facilitate profiling of basic features.
+
+The views and the wsgi middleware are activated when the 'profile' option is
+given. This can be done on the command line
+(:option:`cubicweb-ctl pyramid --profile`) or in the :ref:`pyramid_settings`.
+
+Views
+-----
+
+The following routes and corresponding views are provided when profiling is on:
+
+-   ``/_profile/ping``: Reply 'ping' without doing anything else. See also
+    :func:`cubicweb.pyramid.profile.ping`.
+
+-   ``/_profile/cnx``: Reply 'ping' after getting a cnx. See also
+    :func:`cubicweb.pyramid.profile.cnx`.
+
+Typical Usage
+-------------
+
+Let's say we want to measure the cost of having a ``cnx``.
+
+-   Start the application with profile enabled:
+
+    .. code-block:: console
+
+        $ cubicweb-ctl pyramid --no-daemon --profile --profile-dump-every 100
+
+-   Use 'ab' or any other http benchmark tool to throw a lot of requests:
+
+    .. code-block:: console
+
+        $ ab -c 1 -n 100 http://localhost:8080/_profile/cnx
+
+-   Analyse the results. I personnaly fancy SnakeViz_:
+
+    .. code-block:: console
+
+        $ snakeviz program.prof
+
+.. _SnakeViz: http://jiffyclub.github.io/snakeviz/