Skip to main content
This is a pre-production deployment of Warehouse. Changes made here affect the production instance of PyPI (pypi.python.org).
Help us improve Python packaging - Donate today!

WSGI middleware for line-by-line profiling

Project Description

wsgi_lineprof is a WSGI middleware for line-by-line profiling.

wsgi_lineprof shows results of line-by-line profiling per request. You can use this project with many WSGI-compatible applications and frameworks:

  • Django
  • Pyramid
  • Flask
  • Bottle
  • etc…

At a Glance

You can use wsgi_lineprof as a WSGI middleware of existing applications.

$ pip install wsgi_lineprof

Example usage with Bottle:

import time

import bottle
from wsgi_lineprof.middleware import LineProfilerMiddleware

app = bottle.default_app()


@app.route('/')
def index():
    time.sleep(1)
    return "Hello world!!"

if __name__ == "__main__":
    # Add wsgi_lineprof as a WSGI middleware!
    app = LineProfilerMiddleware(app)
    bottle.run(app=app)

Run the above script to start web server, then access http://127.0.0.1:8080.

The results are outputted to stdout by default. You can see the results like this:

... (snip) ...

File: ./app.py
Name: index
Total time: 1.00518 [sec]
  Line      Hits         Time  Code
===================================
     9                         @app.route('/')
    10                         def index():
    11         1      1005175      time.sleep(1)
    12         1            4      return "Hello world!!"

... (snip) ...

Results contain many other functions, you can remove unnecessary results by using filters.

Requirements

  • Python 2.7
  • Python 3.3
  • Python 3.4
  • Python 3.5
  • Python 3.6

Filters

You can get results from specific files or sort results by using filters. For example, use FilenameFilter to filter results with filename and use TotalTimeSorter to sort results by total_time.

import time

import bottle
from wsgi_lineprof.filters import FilenameFilter, TotalTimeSorter
from wsgi_lineprof.middleware import LineProfilerMiddleware

app = bottle.default_app()


def get_name():
    # Get some data...
    time.sleep(1)
    return "Monty Python"

@app.route('/')
def index():
    name = get_name()
    return "Hello, {}!!".format(name)

if __name__ == "__main__":
    filters = [
        # Results which filename contains "app2.py"
        FilenameFilter("app2.py"),
        # Sort by total time of results
        TotalTimeSorter(),
    ]
    # Add wsgi_lineprof as a WSGI middleware
    app = LineProfilerMiddleware(app, filters=filters)

    bottle.run(app=app)

Run the above script to start web server, then access http://127.0.0.1:8080. You can see results in stdout.

$ ./app2.py
Bottle v0.12.10 server starting up (using WSGIRefServer())...
Listening on http://127.0.0.1:8080/
Hit Ctrl-C to quit.

Time unit: 1e-06 [sec]

File: ./app2.py
Name: index
Total time: 1.00526 [sec]
  Line      Hits         Time  Code
===================================
    15                         @app.route('/')
    16                         def index():
    17         1      1005250      name = get_name()
    18         1           11      return "Hello, {}!!".format(name)

File: ./app2.py
Name: get_name
Total time: 1.00523 [sec]
  Line      Hits         Time  Code
===================================
    10                         def get_name():
    11                             # Get some data...
    12         1      1005226      time.sleep(1)
    13         1            4      return "Monty Python"

127.0.0.1 - - [30/Nov/2016 17:21:12] "GET / HTTP/1.1" 200 21

There are some useful filters in wsgi_lineprof.filters.

Stream

By using stream option, you can output results to a file. For example, you can output logs to lineprof.log.

with open("lineprof.log", "w") as f:
    app = LineProfilerMiddleware(app, stream=f)
    bottle.run(app=app)
Release History

Release History

This version
History Node

0.3.0

History Node

0.2.0

History Node

0.1.1

Download Files

Download Files

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

File Name & Checksum SHA256 Checksum Help Version File Type Upload Date
wsgi_lineprof-0.3.0-cp27-cp27m-macosx_10_12_x86_64.whl (23.4 kB) Copy SHA256 Checksum SHA256 cp27 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp27-cp27m-manylinux1_x86_64.whl (67.1 kB) Copy SHA256 Checksum SHA256 cp27 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp27-cp27mu-manylinux1_x86_64.whl (67.1 kB) Copy SHA256 Checksum SHA256 cp27 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp33-cp33m-macosx_10_10_x86_64.whl (23.9 kB) Copy SHA256 Checksum SHA256 cp33 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp33-cp33m-manylinux1_x86_64.whl (69.6 kB) Copy SHA256 Checksum SHA256 cp33 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp34-cp34m-macosx_10_12_x86_64.whl (23.9 kB) Copy SHA256 Checksum SHA256 cp34 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp34-cp34m-manylinux1_x86_64.whl (72.9 kB) Copy SHA256 Checksum SHA256 cp34 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp35-cp35m-macosx_10_12_x86_64.whl (23.8 kB) Copy SHA256 Checksum SHA256 cp35 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp35-cp35m-manylinux1_x86_64.whl (72.3 kB) Copy SHA256 Checksum SHA256 cp35 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp36-cp36m-macosx_10_12_x86_64.whl (23.8 kB) Copy SHA256 Checksum SHA256 cp36 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0-cp36-cp36m-manylinux1_x86_64.whl (72.5 kB) Copy SHA256 Checksum SHA256 cp36 Wheel Jan 18, 2017
wsgi_lineprof-0.3.0.tar.gz (33.7 kB) Copy SHA256 Checksum SHA256 Source Jan 18, 2017

Supported By

WebFaction WebFaction Technical Writing Elastic Elastic Search Pingdom Pingdom Monitoring Dyn Dyn DNS Sentry Sentry Error Logging CloudAMQP CloudAMQP RabbitMQ Heroku Heroku PaaS Kabu Creative Kabu Creative UX & Design Fastly Fastly CDN DigiCert DigiCert EV Certificate Rackspace Rackspace Cloud Servers DreamHost DreamHost Log Hosting