Skip to main content

Barebones websocket extension for Flask, using Pythonthreading for low-traffic concurrency

Project description

Flask-Threaded-Sockets

Barebones WebSockets for your low-traffic Flask apps.

Simple usage of route decorator:

from flask import Flask
from flask_threaded_sockets import Sockets, ThreadedWebsocketServer


app = Flask(__name__)
sockets = Sockets(app)


@sockets.route('/echo')
def echo_socket(ws):
    while not ws.closed:
        message = ws.receive()
        ws.send(message)


@app.route('/')
def hello():
    return 'Hello World!'


if __name__ == "__main__":
    srv = ThreadedWebsocketServer("0.0.0.0", 5000, app)
    srv.serve_forever()

Usage of Flask blueprints:

from flask import Flask, Blueprint
from flask_threaded_sockets import Sockets, ThreadedWebsocketServer


html = Blueprint(r'html', __name__)
ws = Blueprint(r'ws', __name__)


@html.route('/')
def hello():
    return 'Hello World!'

@ws.route('/echo')
def echo_socket(socket):
    while not socket.closed:
        message = socket.receive()
        socket.send(message)


app = Flask(__name__)
sockets = Sockets(app)

app.register_blueprint(html, url_prefix=r'/')
sockets.register_blueprint(ws, url_prefix=r'/')


if __name__ == "__main__":
    srv = ThreadedWebsocketServer("0.0.0.0", 5000, app)
    srv.serve_forever()

Serving WebSockets in Python was really easy, if you used Gevent, AsyncIO, etc. Now it's easy if you just want to use a threaded development server.

Why would you ever want this?

This should not be used in deployed web apps with lots of requests expected! We developed this library for use in low-traffic IoT devices that benefit from using native Python threads

Almost every Python websocket tutorial out there will tell you to use an async library like AsyncIO, Gevent, Tornado etc. For virtually all applications, this is absolutely true. These async libraries allow you to handle a huge number of concurrent requests, even long-running connections like websockets, with minimal overhead.

In these cases, native threading is heavily discouraged. Most threaded production servers will use a small pool of threads to handle concurrency, and websockets will quickly saturate this pool. Async concurrency libraries get around this by allowing a virtually unlimited number of concurrent requests to be processed.

One way to use native threads without risking pool saturation would be to spawn a thread per client, however it's obvious to see why this would be problematic for large public web apps: One thread per client will quickly lead to an infeasible number of native threads, introducing a huge context-switching overhead.

However, for small services, such as local WoT devices, this is absolutely fine. If you only expect a small (<50) number of simultaneous connections, native threads are perfectly viable as a concurrency provider. Moreover, unlike most async libraries, you're able to easily integrate existing code without having to add async/await keywords, or monkey-patch libraries. For instrument control, this is ideal. We get the full capabilities of Python threading, and it's synchronisation primitives, unmodified use of existing device control code, and no need for monkey-patching.

Installation

To install Flask-Sockets, simply:

pip install flask-threaded-sockets

WebSocket interface

The websocket interface that is passed into your routes is the same as gevent-websocket. The basic methods are fairly straightforward —  send, receive, send_frame, and close.

Project details


Download files

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

Source Distribution

flask_threaded_sockets-0.3.2.tar.gz (29.1 kB view details)

Uploaded Source

Built Distribution

flask_threaded_sockets-0.3.2-py3-none-any.whl (29.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: flask_threaded_sockets-0.3.2.tar.gz
  • Upload date:
  • Size: 29.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.9 CPython/3.8.5 Windows/10

File hashes

Hashes for flask_threaded_sockets-0.3.2.tar.gz
Algorithm Hash digest
SHA256 56517d33d1e8d34573a33abd728ec2cfbbf7e78a339f1bd30b31e8045bd68ad4
MD5 b4abf4fa31186ba19866177d27127cdd
BLAKE2b-256 3ce8f771f107c6d201b60f668f426901e71c82901bbfeb4f1056b4ed5a5705c8

See more details on using hashes here.

File details

Details for the file flask_threaded_sockets-0.3.2-py3-none-any.whl.

File metadata

File hashes

Hashes for flask_threaded_sockets-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 2c4af113f806b2338a1d572d8713b5c7f5f32e0c1763e426a3982d3c0c5f3d08
MD5 707f623f8aa4f3f1d2952b23e4a27ab8
BLAKE2b-256 a30c7bf9fc5f9fe133a7375f28e4a6df13074cb46fb07d9d408ba1dc5207bb03

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