description |
---|
This article walks through how to configure Quality of Service for Gravitee v4 APIs |
Quality of Service (QoS) defines the guaranteed level of message delivery of an asynchronous APIs or event broker. While higher Quality of Service corresponds to more reliable message delivery, this could lead to lower system performance. Different QoS are available for every entrypoint/endpoint combination.
The different levels of QoS are defined below:
Level | Description |
---|---|
None |
|
Auto (0 or N) |
|
At-Most-Once (0 or 1) |
|
At-Least-Once (1 or N) |
|
Quality of Service is set on the entrypoints. A given QoS may or may not be supported by a given endpoint. Support also depends on the protocol used for the entrypoint. The following table outlines QoS compatibility:
MQTT5 | Kafka | Solace | RabbitMQ | |
---|---|---|---|---|
HTTP POST | None Auto | None Auto | None Auto | None Auto |
HTTP GET | Auto | Auto At-Least-Once At-Most-Once | Auto | Auto At-Least-Once At-Most-Once |
SSE | None Auto | None Auto At-Least-Once At-Most-Once | None Auto | None Auto At-Least-Once At-Most-Once |
WebSocket | None Auto | None Auto | None Auto | None Auto |
Webhook | None Auto At-Least-Once At-Most-Once | None Auto At-Least-Once At-Most-Once | None Auto At-Least-Once At-Most-Once | None Auto At-Least-Once At-Most-Once |
You can set QoS levels with the qos
object of the entrypoints
object, as shown in the following example. See the Management API openapi.json
for a list of possible qos
values.
"entrypoints": [
{
"type": "sse",
"qos": "none",
"configuration": {
"heartbeatIntervalInMs": 5000,
"metadataAsComment": false,
"headersAsComment": false
}
}
]