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.2.tar.gz
(4.3 kB
view hashes)
Built Distribution
Close
Hashes for flask_dramatiq-0.2.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3820d0b59235aee501f57017f4faebbb10247c0612f548bcbdf9d40c781e63ee |
|
MD5 | 7af8fb4d41fd0497540d3ca86c97024b |
|
BLAKE2b-256 | 2d346dff326f1fd7bacaa44f7d98d6844a8af751081d8e03c37ea323cea1d00c |