Skip to main content

WSGI Profiling middleware

Project description

linesman is a much needed profiler-for-WSGI applications. It installs as middleware, can be configured entirely from any paster config, and aims to be a jack-of-all-trades when it comes to profiling WSGI apps.

Since a picture is worth a thousand words, here are a few screenshots of the interface:

The changelog can always be viewed from the source, or on PyPi. Keep in mind, PyPi is only updated with each release, and does not include development documentation.

Reasoning behind this library

One of my team’s stories at work was to investigate existing Python profiling tools for use with some of our new web stacks (all in Pylons). I looked at a few–repoze.profile, kea.profile, and even dozer (still in 0.2alpha)–but couldn’t find any that suited our use case. We wanted to…

  • visualize the flow of our code

  • identify bottlenecks quickly and easily

  • have the ability to strip out extraneous calls

Many of the tools simply outputted the pstats object from cProfile, which can be difficult to parse, and even more difficult to identify the call order. Considering that cProfile provided all the information needed, I figured it would be just as easy to write our own middleware.

linesman is a name given to people who inspect electrical Pylons, and was a meek attempt at having a relevant library name.

Setting up middleware

Now, you’ll need to tell your WSGI application how to use Linesman. Assuming you’re using Paster, you can do this very easily in your development.ini (or similar) config file. Add a new filter section:

[filter:linesman]
use = egg:linesman#profiler

Then, find the section for your specific application. Typically, it will have a section header that looks like [app:main]. Add the following config option somewhere within this section:

filter-with = linesman

Wallah! Once you start your paster server, you’ll be all set. Verify that all is working correctly by accessing pages on your server. This will also create profile entries for the next step.

Accessing the profiles

This will assume that your application is mounted at the root directory, /, and that your server is running on localhost at port 5000. If not, make sure you adjust your URLs accordingly.

Access the URL at http://127.0.0.1:5000/__profiler__, which should present you with a list of profiles and times, with a link to the stats page. If you can see this (and view the profiles), then you’re all set!

Happy profiling!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

linesman-0.3.2.zip (115.1 kB view details)

Uploaded Source

linesman-0.3.2.tar.gz (102.4 kB view details)

Uploaded Source

File details

Details for the file linesman-0.3.2.zip.

File metadata

  • Download URL: linesman-0.3.2.zip
  • Upload date:
  • Size: 115.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for linesman-0.3.2.zip
Algorithm Hash digest
SHA256 34ff78d17a90a7d5b20e12537b77dcb4b2b092ac24b97206d8e379ee15fb7ebe
MD5 2bd91d144487634654cf4d1b87d186c3
BLAKE2b-256 9e38b0d18f65a077711ee5c37fcc46ca28cfd7a3017c6652bf951b1f0afc39cc

See more details on using hashes here.

File details

Details for the file linesman-0.3.2.tar.gz.

File metadata

  • Download URL: linesman-0.3.2.tar.gz
  • Upload date:
  • Size: 102.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for linesman-0.3.2.tar.gz
Algorithm Hash digest
SHA256 319b6085ee89981409edaa436457446f6ac96c1dff1af5de90eeccd76a1ec0b0
MD5 8fadb0af5426d3d2b1aa36a3b75419ec
BLAKE2b-256 00dbbbe43c0d4622187a4bae2ba8fd176f18a904a0c36c7a2283280fff2a1c9a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page