INADA Naoki 9e4bd9a772 klein: Close SQLAlchemy's session for each request 10 år sedan
..
AsyncIO c23b05d5c6 Disable fortunes query 10 år sedan
bottle e4ca84da07 bottle: Update requirements 10 år sedan
cherrypy dbe9be57f8 cherrypy: Update requirements 10 år sedan
django 1509b247ac django: Fix HttpResponse argument 10 år sedan
falcon 531fabcbbf falcon: Update requirements 10 år sedan
flask a09b36673a python: Update READMEs 10 år sedan
historical 7a8f5afa54 Removing wget in favor of curl 10 år sedan
klein 9e4bd9a772 klein: Close SQLAlchemy's session for each request 10 år sedan
pyramid 2169209e6f pyramid: Update requirements 10 år sedan
tornado 9f97da0e82 tornado: Fix WARN for mongodb 10 år sedan
turbogears 595bdc3524 Use Jinja2's autoescpae instead of bleach.clean() 10 år sedan
uwsgi b8811fd266 uwsgi: Update requirements 10 år sedan
web2py 8c3e9c4fbf Merge pull request #1657 from sp1d3rx/patch-3 10 år sedan
wheezyweb d5831a828a wheezyweb: Update requirements 10 år sedan
wsgi a09b36673a python: Update READMEs 10 år sedan
.gitignore c3b3772e3e Add more strategies with API-Hour+AsyncIO 10 år sedan
README.md 3e5dc0e676 Merge pull request #1620 from Eyepea/asyncio_reorganization 10 år sedan

README.md

Python frameworks

The information below contains information specific to Python. For further guidance, review the documentation.

Infrastructure Software Versions

Get Help

Python Experts

  • INADA Naoki (@methane) -- Expert of Python and Python's MySQL driver.
  • Ludovic Gasc (@GMLudo) -- Expert of AsyncIO.

Python Community

Python interpreters

(C)Python 3

Newest Python.

It will be most major interpreter for Web Development in this or next year. This is a bit slower than CPython 2, but more simple and productive than it.

(C)Python 2

Legacy Python.

It is most major interpreter for now.

PyPy

PyPy is the fastest Python implementation with JIT.

There is PyPy's Python 3 implementation (PyPy3), but it is not so tuned like PyPy2. So we don't use it for now.

WSGI Servers

Nginx + uWSGI

This is one of fast and realistic way to serve Python web application.

Use unix domain socket between nginx and uWSGI to avoid additional TCP/IP overhead.

Gunicorn + Meinheld

Meinheld is very fast WSGI server.

Since Meinheld is safe against slowloris and support Keep-Alive, you can use it without buffered HTTP reverse proxy (like nginx).

We use meinheld to measure bare (without DB access) performance of framework without overhead of reverse proxying. (plaintext, json test)

Meinheld does not provide worker process management. Gunicorn provide it for Meinheld.

Gunicorn + Tornado

uWSGI + PyPy is difficult to setup. Meinheld doesn't so fast with PyPy because it uses Python/C API heavily. So we use Tornado as HTTP/WSGI server.

It supports keep-alive. So it have nice performance about json or plaintext benchmark.

Before writing new tests.

Don't increase matrix without significant purpose.

We can't maintain matrix of frameworks (5~) * servers (3~) * DBs (3) * Interpreters (3).

If you want to know about performance difference between MySQL and PostgreSQL, there are no need to all frameworks implement both of them. Additionally, Python is not a good language to measure performance of DBs because web application written in Python is slower than DBs.

If you want to benchmark http server, you should not port all tests or frameworks. Simple json or plaintext test is enough.

If your framework uses SQLAlchemy, Flask may be enough to know performance of SQLAlchemy.

Advice when writing new tests

Interpreter

Consider Python 3 first. -- Python 3 will be mainstream for web development soon.

Server

Try Gunicorn + Meinheld first. All WSGI apps in this benchmark uses it. You can compare your framework performance with others.

Files you should provide

You can see Flask's files to know how to write new test.

requirements.txt is standard way to define depending libraries.

install.sh is executed before running test. You should create virtualenv on $TROOT/py2 (or py3 for Python 3 and pypy for PyPy). Then $TROOT/py2/bin/pip install -r requirements.txt. virtualenv is installed on Python 2 and PyPy. Use $IROOT/py3/bin/python3 -m venv $TROOT/py3 for Python 3.

You can set environment variables within install.sh or within setup.sh.

bechmark_config is json file to define test. See here.

setup_py2.sh is used to run test on Python 2. gunicorn_conf.py is configuration for gunicorn. setup_py2.sh and gunicorn_conf.py are written as generic as possible. You may be able to use it with changing wsgi callable. ($PY2_GUNICORN wsgimodule:callable -c gunicorn_conf.py)