Adds Dramatiq support to your Flask application
Project description
// Flask-Dramatiq //
Flask-Dramatiq plugs Dramatiq in your Flask application.
Features
- Configure Dramatiq from Flask configuration.
- Ensure Flask app is available to Dramatiq actor.
- Add
worker
command to Flask CLI. - Enable Flask Application factory.
Installation and Usage
Flask-Dramatiq is licensed under BSD-3-Clause. Add flask-dramatiq
to your
project:
$ poetry add flask-dramatiq
Then use Dramatiq
object as a regular Flask extension:
from flask import Flask
from flask_dramatiq import Dramatiq
app = Flask(__name__)
dramatiq = Dramatiq(app)
@dramatiq.actor()
def my_actor():
...
@app.route("/")
def myhandler():
my_actor.send()
Flask-Dramatiq adds two configuration keys:
DRAMATIQ_BROKER
, points to broker class likedramatiq.brokers.rabbitmq.RabbitmqBroker
ordramatiq.brokers.redis.RedisBroker
.DRAMATIQ_BROKER_URL
is passed asurl
keyword argument to broker class.
Now run worker program to consume messages and execute tasks in the background:
$ flask worker --processes=1
A complete flask app is available in project source tree example.py.
Credit and Support
Feel free to open an issue or suggest a merge request on Gitlab project page. Contribution welcome!
The project is based on Bogdanp/flask_dramatiq_example.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
flask-dramatiq-0.2.1.tar.gz
(4.2 kB
view hashes)
Built Distribution
Close
Hashes for flask_dramatiq-0.2.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 479c0927a2d229935eeee958e2b613d4468dbb378509133a137d4018588e46ae |
|
MD5 | 89e6a50af4e85ab6df583397d5591314 |
|
BLAKE2b-256 | 71d2fbee89a1a9efd03510bf2550aa716488bef0eb1c83130cf657dfe3f78307 |