Radoslav Petrov ed0804d716 Allocate on each request the variable representing the JSON data (#3193) 7 years ago
..
aiohttp 954fdf53db upgrade packages for aiohttp (#2874) 8 years ago
api_hour 697e54bada Misc. Clean Up (#2773) 8 years ago
apistar 46959e5797 Added API Star to Python frameworks. (#2633) 8 years ago
bottle 363a51a0cb bottle ujson optional dependency (#2947) 7 years ago
cherrypy 697e54bada Misc. Clean Up (#2773) 8 years ago
django bc55aba913 Python/Django: Upgrade Django 1.11 to 2.0 (#3164) 7 years ago
falcon 882490524e Upgrade Python 3 + PyPy => PyPy2 rename + PyPy3 integration (#2918) 8 years ago
flask 887be0ed46 Python/Flask update (#3055) 7 years ago
japronto 15dec7b95f Add japronto (#3002) 7 years ago
klein 697e54bada Misc. Clean Up (#2773) 8 years ago
morepath bed1da66fe Add Morepath framework to Python (#2903) 8 years ago
pyramid e9c5f6f782 DB Setup Changes / New Travis / Vagrant fix - The Promised Land! (#2417) 8 years ago
sanic b12796b563 Add Sanic (#3127) 7 years ago
tornado ed0804d716 Allocate on each request the variable representing the JSON data (#3193) 7 years ago
turbogears e9c5f6f782 DB Setup Changes / New Travis / Vagrant fix - The Promised Land! (#2417) 8 years ago
uvicorn 7ec12a6525 Upgrade uvicorn version (#2907) 8 years ago
uwsgi c621b4196c Add CPU_COUNT env variable / get MAX_THREADS for load_gen (#2586) 8 years ago
web2py 0b404acd1c update web2py to v2.16.1 (#3169) 7 years ago
webware fb52f27dbd Remove the useless "historical" directory, promote webware to top level (#3071) 7 years ago
weppy a4d7fe4b35 Updated weppy framework (#3005) 7 years ago
wheezyweb e9c5f6f782 DB Setup Changes / New Travis / Vagrant fix - The Promised Land! (#2417) 8 years ago
wsgi 9951ab4507 upgrade python3 to 3.6 (#2528) 8 years ago
.gitignore 3686d77ba5 Ignore __pycache__ 9 years ago
README.md 882490524e Upgrade Python 3 + PyPy => PyPy2 rename + PyPy3 integration (#2918) 8 years ago

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) -- CPython core developer and expert of Python's MySQL driver.
  • Ludovic Gasc (@GMLudo) -- AsyncIO and aiohttp user.

Python Community

Python interpreters

(C)Python 3

Newest Python.

It is the most major interpreter for Web Development.

(C)Python 2

Legacy Python. Still used for widely.

PyPy3

PyPy is the fastest Python implementation with JIT.

PyPy2

Legacy PyPy. Still used for widely.

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 is mainstream for web development.

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)