ASGI Support#
Often, you need not only to run your application to consume messages but also to make it a part of your service ecosystem with Prometheus metrics, K8S liveness and readiness probes, traces, and other observability features.
Unfortunately, such functionalilty can't be implemented by broker features alone, and you have to provide several HTTP endpoints in your app.
Of course, you can use FastStream as a part of any ASGI frameworks (integrations), but fewer the dependencies, the better, right?
AsgiFastStream#
Fortunately, we have built-in ASGI support. It is very limited but good enough to provide you with basic functionality for metrics and healthcheck endpoint implementation.
Let's take a look at the following example:
main.py | |
---|---|
This simple example allows you to run the app using regular ASGI servers:
It does nothing but launch the app itself as an ASGI lifespan.
Note
If you want to run your app using several workers, you need to use something else than uvicorn
.
ASGI Routes#
It doesn't look very helpful, so let's add some HTTP endpoints.
First, we have already written a wrapper on top of the broker to make a ready-to-use ASGI healthcheck endpoint for you:
Note
This /health
endpoint calls the broker.ping()
method and returns HTTP 204 or HTTP 500 statuses.
Custom ASGI Routes#
AsgiFastStream is able to call any ASGI-compatible callable objects, so you can use any endpoints from other libraries if they are compatible with the protocol.
If you want to write your own simple HTTP-endpoint, you can use our @get
decorator as in the following example:
Tip
You do not need to setup all routes using the asgi_routes=[]
parameter.
You can use the app.mount("/health", asgi_endpoint)
method also.
AsyncAPI Documentation#
You can also host your AsyncAPI documentation in the same process, by running faststream docs serve ...
, in the same container and runtime.
Just create an AsgiFastStream
object with a special option:
Now, your AsyncAPI HTML representation can be found by the /docs
url.
FastStream Object Reuse#
You may also use regular FastStream
application object for similar result.
Tip
For apps that use ASGI, you may use the CLI command just like for the default FastStream app
This possibility built on gunicorn + uvicorn, you need install them to run FastStream ASGI app via CLI. We send all args directly to gunicorn, you can learn more about it here.Other ASGI Compatibility#
Moreover, our wrappers can be used as ready-to-use endpoins for other ASGI frameworks. This can be very helpful When you are running FastStream in the same runtime as any other ASGI frameworks.
Just follow the following example in such cases: