summaryrefslogtreecommitdiffstats
path: root/Doc/using
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@python.org>2023-09-06 15:54:59 (GMT)
committerGitHub <noreply@github.com>2023-09-06 15:54:59 (GMT)
commita0773b89dfe5cd2190d539905dd89e7f6455668e (patch)
treee11c7306e6ed7750265eda6ba8fa49f329bc0f85 /Doc/using
parent8ff11425783806f8cb78e99f667546b1f7f3428e (diff)
downloadcpython-a0773b89dfe5cd2190d539905dd89e7f6455668e.zip
cpython-a0773b89dfe5cd2190d539905dd89e7f6455668e.tar.gz
cpython-a0773b89dfe5cd2190d539905dd89e7f6455668e.tar.bz2
gh-108753: Enhance pystats (#108754)
Statistics gathering is now off by default. Use the "-X pystats" command line option or set the new PYTHONSTATS environment variable to 1 to turn statistics gathering on at Python startup. Statistics are no longer dumped at exit if statistics gathering was off or statistics have been cleared. Changes: * Add PYTHONSTATS environment variable. * sys._stats_dump() now returns False if statistics are not dumped because they are all equal to zero. * Add PyConfig._pystats member. * Add tests on sys functions and on setting PyConfig._pystats to 1. * Add Include/cpython/pystats.h and Include/internal/pycore_pystats.h header files. * Rename '_py_stats' variable to '_Py_stats'. * Exclude Include/cpython/pystats.h from the Py_LIMITED_API. * Move pystats.h include from object.h to Python.h. * Add _Py_StatsOn() and _Py_StatsOff() functions. Remove '_py_stats_struct' variable from the API: make it static in specialize.c. * Document API in Include/pystats.h and Include/cpython/pystats.h. * Complete pystats documentation in Doc/using/configure.rst. * Don't write "all zeros" stats: if _stats_off() and _stats_clear() or _stats_dump() were called. * _PyEval_Fini() now always call _Py_PrintSpecializationStats() which does nothing if stats are all zeros. Co-authored-by: Michael Droettboom <mdboom@gmail.com>
Diffstat (limited to 'Doc/using')
-rw-r--r--Doc/using/configure.rst61
1 files changed, 58 insertions, 3 deletions
diff --git a/Doc/using/configure.rst b/Doc/using/configure.rst
index fe35372..ad58255 100644
--- a/Doc/using/configure.rst
+++ b/Doc/using/configure.rst
@@ -192,14 +192,69 @@ General Options
.. cmdoption:: --enable-pystats
- Turn on internal statistics gathering.
+ Turn on internal Python performance statistics gathering.
+
+ By default, statistics gathering is off. Use ``python3 -X pystats`` command
+ or set ``PYTHONSTATS=1`` environment variable to turn on statistics
+ gathering at Python startup.
+
+ At Python exit, dump statistics if statistics gathering was on and not
+ cleared.
+
+ Effects:
+
+ * Add :option:`-X pystats <-X>` command line option.
+ * Add :envvar:`!PYTHONSTATS` environment variable.
+ * Define the ``Py_STATS`` macro.
+ * Add functions to the :mod:`sys` module:
+
+ * :func:`!sys._stats_on`: Turns on statistics gathering.
+ * :func:`!sys._stats_off`: Turns off statistics gathering.
+ * :func:`!sys._stats_clear`: Clears the statistics.
+ * :func:`!sys._stats_dump`: Dump statistics to file, and clears the statistics.
The statistics will be dumped to a arbitrary (probably unique) file in
- ``/tmp/py_stats/``, or ``C:\temp\py_stats\`` on Windows. If that directory
- does not exist, results will be printed on stdout.
+ ``/tmp/py_stats/`` (Unix) or ``C:\temp\py_stats\`` (Windows). If that
+ directory does not exist, results will be printed on stderr.
Use ``Tools/scripts/summarize_stats.py`` to read the stats.
+ Statistics:
+
+ * Opcode:
+
+ * Specialization: success, failure, hit, deferred, miss, deopt, failures;
+ * Execution count;
+ * Pair count.
+
+ * Call:
+
+ * Inlined Python calls;
+ * PyEval calls;
+ * Frames pushed;
+ * Frame object created;
+ * Eval calls: vector, generator, legacy, function VECTORCALL, build class,
+ slot, function "ex", API, method.
+
+ * Object:
+
+ * incref and decref;
+ * interpreter incref and decref;
+ * allocations: all, 512 bytes, 4 kiB, big;
+ * free;
+ * to/from free lists;
+ * dictionary materialized/dematerialized;
+ * type cache;
+ * optimization attemps;
+ * optimization traces created/executed;
+ * uops executed.
+
+ * Garbage collector:
+
+ * Garbage collections;
+ * Objects visited;
+ * Objects collected.
+
.. versionadded:: 3.11
.. cmdoption:: --disable-gil