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.
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("/healh", 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
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: