Skip to content

Latest commit

 

History

History
47 lines (27 loc) · 1018 Bytes

README.md

File metadata and controls

47 lines (27 loc) · 1018 Bytes

Gotta get get some metrics!

We've gotta go fast, but sure we want to measure how fast, right?

The common way to get the metrics is collect them via StatsD protocol to Grafana or DataDog. It's relatively easy to measure every endpoint by decorating it with @statsd.timed(), but why not automate it?

So once you've configured your statsd client, just pass it to this extension and get the generic metrics automagically.

Usage example

from sanic import Sanic
from sanic.response import text

from sanic_statsd import SanicStatsD

from yourapp.stats import configured_statsd_client as statsd

app = Sanic()
SanicStatsD(app, statsd=statsd, tags=['app:{}'.format(__name__)])


@app.route("/")
async def index(request):
    return text("Ok")

if __name__ == "__main__":
    app.run(host="0.0.0.0", port=8000, debug=True)

And that's, basically, it!


TODO:

[ ] Document init parameters and implement examples of using of

[ ] Implement support for statsd