activemq-artemis/examples/features/standard/rest/jms-to-rest
Clebert Suconic a0e7cb4eae [maven-release-plugin] prepare for next development iteration 2022-03-22 13:34:58 -04:00
..
src/main ARTEMIS-1562 Refactor example documentation 2017-12-15 14:54:16 +00:00
pom.xml [maven-release-plugin] prepare for next development iteration 2022-03-22 13:34:58 -04:00
postOrder.py ARTEMIS-2320 Assorted small code fixes, mostly from IntelliJ autofixes 2019-04-29 11:28:10 +01:00
readme.md ARTEMIS-1562 Refactor example documentation 2017-12-15 14:54:16 +00:00
receiveOrder.py ARTEMIS-2320 Assorted small code fixes, mostly from IntelliJ autofixes 2019-04-29 11:28:10 +01:00

readme.md

Mixed JMS and REST Producers/Consumers Example

This is an example of mixing JMS producers and consumers with REST producers and consumers. The REST clients have been written in both Java using RESTEasy's client library and within the Python language. You will need Python 2.6.1 or higher to be able to run the Python clients.

To run the example you will need 5 shell-script windows (or you'll need to run 4 processes in background)

Step 1:

mvn jetty:run

This will bring up ActiveMQ Artemis and the ActiveMQ Artemis REST Interface.

Step 2:

mvn exec:java -Dexec.mainClass="RestReceive"

This will bring up a Java REST client that is continuously pulling the broker through a consume-next (see doco for details).

Step 3:

mvn exec:java -Dexec.mainClass="JmsReceive"

This will bring up a Java JMS consumer that is using the MessageListener interface to consume messages. It will extract a Order instance from the JMS Message it receives.

Step 4:

python receiveOrder.py

This runs a very simple Python program to consume messages

Step 5: Use one of these three commands to post messages to the system. One of the receive clients will consume the message.

mvn exec:java -Dexec.mainClass="JmsSend"

A JMS client will create an Order object and send it to the queue. You'll see one of the 4 clients receive the message. Notice that the REST clients automatically cause the Order object to be transformed on the broker and passed as XML to the REST client.

mvn exec:java -Dexec.mainClass="RestSend"

This is a REST client that uses the Acknowledgement protocol to receive a message from the queue.

python postOrder.py

This is a Python client that posts one message to the queue RESTfully (of course ;) )