This project provides some examples of using Spring JMS for both asynchronous and synchronous message consumption.
All of the examples for asynchronous message consumption utilize the Spring DefaultMessageListenerContainer for message consumption.
Spring JMS supports three types of message listeners including:
These three types of message listeners are all demonstrated using examples in the async directory.
These examples are intended to be run from the command-line using Maven. The consumer should be run in one terminal and the producer should be run in a separate terminal. Below are examples of running each of the three asynchronous examples.
- Maven
- Apache ActiveMQ
- HAWTIO (optional)
After you run ActiveMQ, you should connect HAWTIO to it. It has a nice web interface to manage remote queues in ActiveMQ. Then log in and open the page for your local ActiveMQ. On that page, you can find localhost>Queue. Open it up and create a new one (TEST.FOO in this example).
$ cd ./async/message-listener-adapter
$ mvn clean compile
$ mvn -Pproducer exec:java
$ cd ./async/message-listener-adapter
$ mvn clean compile
$ mvn -Pconsumer exec:java
$ cd ./async/message-listener-adapter
$ mvn clean compile
$ mvn -Pproducer exec:java
$ cd ./async/message-listener-adapter
$ mvn clean compile
$ mvn -Pconsumer exec:java
This example requires a couple of arguments, the first one for the destination name and the second one for the message type. The destination name should be either FOO.TEST or FOO.TEST2. The message type should text, bytes, map or object. Below is an example of text:
$ cd ./async/message-listener-adapter
$ mvn clean compile
$ mvn -Pproducer exec:java -Dexec.args="FOO.TEST2 text"
These arguments allow you to invoke one of two MessageListenerAdapter
examples and to send four different types of messages.
$ cd ./async/message-listener-adapter
$ mvn clean compile
$ mvn -Pconsumer exec:java
The example for synchronous message consumption uses the Spring JmsTemplate.
This example is also intended to be run from the command-line using Maven. The consumer should be run in one terminal and the producer should be run in a separate terminal. Below is an example of running the synchronous example.
$ cd ./sync/jms-template
$ mvn clean compile
$ mvn -Pconsumer exec:java
This example supports two different types of sends including a simple convertAndSend and also a jmsSend. These two types are specified using an argument when starting up the producer as shown below:
$ cd ./sync/jms-template
$ mvn clean compile
$ mvn -Pproducer exec:java -DsendType=convertAndSend
If you have any questions about these examples, please create an issue for the project. This will allow everyone to see all questions and answers and it will notify me when folks enter new issues.
I also blog about JMS occasionally. Here are some popular posts I have written about Spring JMS: