Skip to content

jamesroberts/fastwsgi

Folders and files

NameName
Last commit message
Last commit date
Oct 17, 2022
Feb 6, 2025
Nov 10, 2022
Oct 17, 2022
Jan 16, 2022
Mar 15, 2023
Jan 16, 2022
Dec 4, 2021
Mar 21, 2023
Mar 21, 2023
Oct 31, 2022
May 1, 2023
Mar 11, 2023
Mar 15, 2023
Oct 26, 2021
May 2, 2023
Dec 18, 2021
Oct 21, 2021
Dec 13, 2021
Mar 15, 2023
Oct 21, 2021
May 1, 2023
Apr 24, 2023
Oct 29, 2022

Repository files navigation


Tests Pypi Language grade: C/C++ Language grade: Python

FastWSGI

🚧 FastWSGI is still under development.

FastWSGI is an ultra fast WSGI server for Python 3.

Its written in C and uses libuv and llhttp under the hood for blazing fast performance.

Supported Platforms

Platform Linux MacOs Windows
Support ✅ ✅ ✅

Performance

FastWSGI is one of the fastest general use WSGI servers out there!

For a comparison against other popular WSGI servers, see PERFORMANCE.md

Installation

Install using the pip package manager.

pip install fastwsgi

Quick start

Create a new file example.py with the following:

import fastwsgi

def app(environ, start_response):
    headers = [('Content-Type', 'text/plain')]
    start_response('200 OK', headers)
    return [b'Hello, World!']

if __name__ == '__main__':
    fastwsgi.run(wsgi_app=app, host='0.0.0.0', port=5000)

Run the server using:

python3 example.py

Or, by using the fastwsgi command:

fastwsgi example:app

Example usage with Flask

See example.py for more details.

import fastwsgi
from flask import Flask

app = Flask(__name__)


@app.get('/')
def hello_world():
    return 'Hello, World!', 200


if __name__ == '__main__':
    fastwsgi.run(wsgi_app=app, host='127.0.0.1', port=5000)

Testing

To run the test suite using pytest, run the following command:

python3 -m pytest

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests where appropriate.

Significant Contributions

Special thank you to the following individuals who have made significant contributions to FastWSGI:

TODO

  • Comprehensive error handling
  • Complete HTTP/1.1 compliance
  • Unit tests running in CI workflow