You are here: Home / LBN / Up2date / Plone 5 / BastionLinux 36 / python3-dm-zope-profile-1.0-1.lbn36.noarch

python3-dm-zope-profile-1.0-1.lbn36.noarch

Package Attributes
RPM  python3-dm-zope-profile-1.0-1.lbn36.noarch.rpm Architecture  noarch Size  65281 Created  2022/09/06 06:03:08 UTC
Package Specification
Summary Profiling Zope applications (for Zope > 4)
Group Unspecified
License BSD
Home Page https://pypi.org/project/dm.zope.profile
Description

The package allows the profiling of Zope applications. It is the successor of Products.ZopeProfiler for Zope>4. It uses Python's standard profiling support from its runtime library modules cProfile and pstats and integrates it with Zope. Read the corresponding documentation to learn how to interact with and interpret the collected profiling information.

Profiling

When you start a Zope instance, profiling is disabled. You can enable the collection of profiling data via the page @@profile. This page also allows you to configure the profiling and present the collected data in various alternative ways.

The configuration is split into 2 parts: the Profiler part controls the collection of profiling base data, the Statistics part controls how this information is presented.

The Profiler configuration allows you to specify which timer (real time or CPU time) is used for profiling and which requests should be profiled. For the latter task, you can define 2 collections of regular expressions: include and exclude. A request is not profiled if any regular expression in exclude matches; if include is not empty, then a request is only profiled if it matches at least one of those. Matching is always performed in search mode on the request’s PATH_INFO. When you change the timer, the collected profiling data is cleared.

The Statistics configuration essentially provides parameters for Python’s pstats. Especially, you can select various views (stats, caller, callee), sort according to various criteria (e.g. cumulative, internal, …), strip directory information and control the amount of data shown. Read the Python documentation for pstats to get details.

Note that profiling usually does not see thread switches. This is always the case when you use a real time timer and can also be the case with a CPU time timer (e.g. for Python 2 or on Windows). In those cases, time spend in a foreign thread may be wrongly accounted for a profiled request. You may consider configuring Zope to use a single worker thread to reduce this problem.

Note that both configuration and collected profiling data is maintained in process memory; i.e. in a multi instance Zope installation, each instance has its own private data.

Note that profiling reveals important implementation details. You should take appropriate measures to avoid that it can be accessed by a hacker. One option is to make it only available in development installations behind a firewall. Configuration

dm.zope.profile maintains its configuration in RAM. As a consequence, configuration changes are lost when the process is shut down. You can define the initial configuration on start up via ZCML. For this purpose, the package’s meta.zcml defines the directive config in namespace http://namespaces.zope.org/dm.zope.profile.

The configuration uses options with either simple values (timer, type and strip_dirs) or collection values (include, exclude, sort_by, restrictions). Options with simple values are specified via attributes of the config directive. Individual elements of collection values are specified via element subdirectives. Those subdirectives specify the option they provide a partial value for via their name attribute and their contribution via their value attribute.

example_config.zcml contains an example. It recreates the code defined default conflguration (and thus serves only as an a demontration).

Note: Currently, you cannot omit options in order to inherit them from the the code defined default configuration: if the config directive is used, then the code defined default configuration becomes completely irrelevant. This might change in the future.

Requires
rpmlib(PayloadFilesHavePrefix)  
rpmlib(PayloadIsZstd)  
rpmlib(PartialHardlinkSets)  
rpmlib(CompressedFileNames)  
rpmlib(FileDigests)  
Provides
python-dm-zope-profile
python3-dm-zope-profile
python3.10-dm-zope-profile
python3.10dist(dm-zope-profile)
python3.10dist(dm.zope.profile)
python3dist(dm-zope-profile)
python3dist(dm.zope.profile)
Obsoletes
python-dm-zope-profile

Document Actions