This proposal is about removing the current support for the AMQP 1.0 protocol from the Strimzi bridge, leaving just the HTTP support.
Currently the Strimzi bridge provides support for the AMQP 1.0 protocol other than HTTP. The AMQP 1.0 protocol support is provided by using the Vert.x Proton component for handling the communication on the wire. The current implementation comes from a custom design in terms of usage of AMQP 1.0 message properties, addresses and so on but not following any specific standard, like the new available Event Stream Extensions for AMQP Version 1.0.
The AMQP 1.0 protocol support seems not to be used extensively by the Strimzi community. We haven't ever seen users opening GitHub issues or discussions about adding new features or fixing bugs on the AMQP 1.0 part. The same applies on the CNCF Slack #strimzi channel and the mailing lists. Even asking users about their AMQP 1.0 usage didn't get any answer. It seems that the Strimzi bridge is mostly used for its HTTP protocol support, which is where we see more engagement from the users. Currently the AMQP 1.0 support offers no benefit to users and comes with costs to the project:
- costs in terms of a more complex bridge architecture, requiring abstraction over HTTP and AMQP protocols.
- on-going cost for testing.
- an extra Vert.x dependency, the Vert.x Proton component.
Removing it allows to reduce the dependencies surface which could be impacted by bugs and CVEs.
This proposal suggests to remove the AMQP 1.0 protocol support from the Strimzi bridge. It involves removing different parts of the codebase:
- The specific AMQP 1.0 related part in the
io.strimzi.kafka.bridge.amqp
package. - The part which is used for tracking offsets for AMQP 1.0 in the
io.strimzi.kafka.bridge.tracker
package. - Simplifying or even removing the
SinkBridgeEndpoint
andSourceBridgeEndpoint
classes that currently are used as a common layer across AMQP 1.0 and HTTP for interacting with the Apache Kafka cluster. - All the corresponding tests.
- All the documentation about the AMQP 1.0 support design and usage (see
amqp
folder) and configuration for using the Qpid Dispatch Router with it (seeqdrouterd
folder).
In the future, but without any actual roadmap or ETA for it, we could come back to have a support for AMQP 1.0 to Apache Kafka bridging with a separate component under the Strimzi organization and by implementing the Event Stream Extensions for AMQP Version 1.0 OASIS standard.
This proposal affects the Strimzi bridge project only.
The Strimzi operator is not affected because currently it is not possible to enable the AMQP 1.0 support on the bridge through the KafkaBridge
custom resource.
When the removal is completed, the users won't be able to use the AMQP 1.0 protocol support with future bridge releases. If they really need that, the only way is to stick with older bridge versions.
No rejected alternatives to mention.