A dashboard for Dramatiq (Redis-only!).
Project description
dramatiq_dashboard
A dashboard for dramatiq, specific to its Redis broker (sorry RabbitMQ users!). Very alpha stuff.
It comes in the form of a WSGI middleware, with as few dependencies as
possible (dramatiq
, jinja2
and redis
) so it's super easy to plug
into whatever web application you have.
Installation
pip install dramatiq_dashboard
Supporting the Project
If you use and love Dramatiq and want to make sure it gets the love and attention it deserves then you should consider supporting the project. There are three ways in which you can do this right now:
- If you're a company that uses Dramatiq in production then you can get a Tidelift subscription. Doing so will give you an easy route to supporting both Dramatiq and other open source projects that you depend on.
- If you're an individual or a company that doesn't want to go through Tidelift then you can support the project via Patreon.
- If you're a company and neither option works for you and you would like to receive an invoice from me directly then email me at bogdan@defn.io and let's talk.
Quickstart
Run the dashboard on top of an existing WSGI app
# Assuming at some point you instantiate your app.
app = create_wsgi_application()
# Import the library, create the middleware and wrap your app with it.
import dramatiq_dashboard
dashboard_middleware = dramatiq_dashboard.make_wsgi_middleware("/drama")
app = dashboard_middleware(app)
Run your app, visit /drama
and you should see the dashboard.
Run the dashboard as a standalone webserver
If you don't want to wrap an existing WSGI app, you can also run the
dashboard as a standalone server. Install the WSGI server of your
choice (e.g. uWSGi, gunicorn, bjoern, etc), setup the Redis broker,
and then start DashboardApp
directly.
For example, to serve the dashboard on http://127.0.0.1:8080
using
the bjoern
WSGI server and a redis server on 17.0.0.1:6379
, run
the following:
import bjoern
import dramatiq
from dramatiq.brokers.redis import RedisBroker
from dramatiq_dashboard import DashboardApp
broker = RedisBroker(host="127.0.0.1", port=6379)
dramatiq.set_broker(broker)
app = DashboardApp(broker=broker, prefix="")
bjoern.run(app, "127.0.0.1", 8080)
Then visit http://127.0.0.1:8080/ to see the running dashboard.
Note that if you use custom queues in your application, they won't be
discovered using this approach. You'll have to either add each one of
them manually to your broker or import and pass your application's
broker to DashboardApp
.
License
dramatiq_dashboard is licensed under the LGPL. Please see COPYING and COPYING.LESSER for licensing details.
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
Built Distribution
File details
Details for the file dramatiq_dashboard-0.2.1.tar.gz
.
File metadata
- Download URL: dramatiq_dashboard-0.2.1.tar.gz
- Upload date:
- Size: 28.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 75b8efa2ea8bce128baef02a1a0fd839f66c047810992ef6e76ae52df7956668 |
|
MD5 | c2044b605f9e09ff40174b68b9fbd482 |
|
BLAKE2b-256 | 67c0faceb28af86dc5c3fa15e01c38ae0b14e486bb08de50371c5cd0b0a28e81 |
Provenance
File details
Details for the file dramatiq_dashboard-0.2.1-py3-none-any.whl
.
File metadata
- Download URL: dramatiq_dashboard-0.2.1-py3-none-any.whl
- Upload date:
- Size: 31.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9ff925cbbcbe336fe642ea42aec6b48b7c307dd03195ab318ac80cfcddfe2109 |
|
MD5 | a01caea7ed0bec8781ca08664e30da88 |
|
BLAKE2b-256 | 435fd70b70c7af0327fa3d2fd1cee81811263c6dbd92244a9de718045683d6ce |