| // Do not edit directly! |
| // This file was generated by camel-quarkus-maven-plugin:update-extension-doc-page |
| [id="extensions-amqp"] |
| = AMQP |
| :page-aliases: extensions/amqp.adoc |
| :linkattrs: |
| :cq-artifact-id: camel-quarkus-amqp |
| :cq-native-supported: true |
| :cq-status: Stable |
| :cq-status-deprecation: Stable |
| :cq-description: Messaging with AMQP protocol using Apache QPid Client. |
| :cq-deprecated: false |
| :cq-jvm-since: 1.0.0 |
| :cq-native-since: 1.0.0 |
| |
| ifeval::[{doc-show-badges} == true] |
| [.badges] |
| [.badge-key]##JVM since##[.badge-supported]##1.0.0## [.badge-key]##Native since##[.badge-supported]##1.0.0## |
| endif::[] |
| |
| Messaging with AMQP protocol using Apache QPid Client. |
| |
| [id="extensions-amqp-whats-inside"] |
| == What's inside |
| |
| * xref:{cq-camel-components}::amqp-component.adoc[AMQP component], URI syntax: `amqp:destinationType:destinationName` |
| |
| Please refer to the above link for usage and configuration details. |
| |
| [id="extensions-amqp-maven-coordinates"] |
| == Maven coordinates |
| |
| https://{link-quarkus-code-generator}/?extension-search=camel-quarkus-amqp[Create a new project with this extension on {link-quarkus-code-generator}, window="_blank"] |
| |
| Or add the coordinates to your existing project: |
| |
| [source,xml] |
| ---- |
| <dependency> |
| <groupId>org.apache.camel.quarkus</groupId> |
| <artifactId>camel-quarkus-amqp</artifactId> |
| </dependency> |
| ---- |
| ifeval::[{doc-show-user-guide-link} == true] |
| Check the xref:user-guide/index.adoc[User guide] for more information about writing Camel Quarkus applications. |
| endif::[] |
| |
| [id="extensions-amqp-usage"] |
| == Usage |
| [id="extensions-amqp-usage-message-mapping-with-org-w3c-dom-node"] |
| === Message mapping with `org.w3c.dom.Node` |
| |
| The Camel AMQP component supports message mapping between `jakarta.jms.Message` and `org.apache.camel.Message`. When wanting to convert a Camel message body type of `org.w3c.dom.Node`, |
| you must ensure that the `camel-quarkus-xml-jaxp` extension is present on the classpath. |
| |
| [id="extensions-amqp-usage-native-mode-support-for-jakarta-jms-objectmessage"] |
| === Native mode support for jakarta.jms.ObjectMessage |
| |
| When sending JMS message payloads as `jakarta.jms.ObjectMessage`, you must annotate the relevant classes to be registered for serialization with `@RegisterForReflection(serialization = true)`. |
| Note that this extension automatically sets `quarkus.camel.native.reflection.serialization-enabled = true` for you. Refer to the xref:user-guide/native-mode.adoc#serialization[native mode user guide] for more information. |
| |
| [id="extensions-amqp-usage-connection-pooling"] |
| === Connection Pooling |
| |
| You can use the `quarkus-pooled-jms` extension to get pooling support for the connections. Refer to the https://quarkiverse.github.io/quarkiverse-docs/quarkus-pooled-jms/dev/index.html[quarkus-pooled-jms] extension documentation for more information. |
| |
| Just add the following dependency to your `pom.xml`: |
| [source,xml] |
| ---- |
| <dependency> |
| <groupId>io.quarkiverse.messaginghub</groupId> |
| <artifactId>quarkus-pooled-jms</artifactId> |
| </dependency> |
| ---- |
| |
| To enable the pooling support, you need to add the following configuration to your `application.properties`: |
| [source,properties] |
| ---- |
| quarkus.qpid-jms.wrap=true |
| ---- |
| |
| |
| [id="extensions-amqp-transferexception-option-in-native-mode"] |
| == transferException option in native mode |
| |
| To use the `transferException` option in native mode, you must enable support for object serialization. Refer to the xref:user-guide/native-mode.adoc#serialization[native mode user guide] |
| for more information. |
| |
| You will also need to enable serialization for the exception classes that you intend to serialize. For example. |
| [source,java] |
| ---- |
| @RegisterForReflection(targets = { IllegalStateException.class, MyCustomException.class }, serialization = true) |
| ---- |
| |
| [id="extensions-amqp-additional-camel-quarkus-configuration"] |
| == Additional Camel Quarkus configuration |
| |
| The extension leverages the https://github.com/amqphub/quarkus-qpid-jms/[Quarkus Qpid JMS] extension. A ConnectionFactory bean is automatically created |
| and wired into the AMQP component for you. The connection factory can be configured |
| via the Quarkus Qpid JMS https://github.com/amqphub/quarkus-qpid-jms#configuration[configuration options]. |
| |