Apache Artemis – How to produce/consume JMS messages with SpringBoot Artemis applications.

Apache ActiveMQ Artemis is a combined feature-set of ActiveMQ/HornetQ/Apollo. It provides a non blocking architecture for an outstanding performance. So in the tutorial, JavaSampleApproach will guide how to
create JMS producer/consumer by SpringBoot Artemis applications.

Related posts:
Spring JMS with ActiveMQ – JMS Consumer and JMS Producer | Spring Boot
Spring Apache Kafka Application with SpringBoot Auto-Configuration
Spring RabbitMQ Producer/Consumer applications with SpringBoot

I. Technologies

– Java 8
– Maven 3.6.1
– Spring Tool Suite: Version 3.8.4.RELEASE
– Spring Boot: 1.5.4.RELEASE
– Apache Artemis 2.1.0

II. SpringBoot Artemis

1. SpringBoot Auto-configure

When having artemis-jms-client Artemis on the classpath, Spring Boot can auto-configure a ConnectionFactory.
We use spring.artemis.* to control Artemis configuration:

spring.artemis.mode has 2 mode: {NATIVE, EMBEDDED}:
NATIVE: Connect to a broker using the native Artemis protocol.
EMBEDDED: Embed the broker in the application.

2. Sending/Receiving messages

For sending message, we use: JmsTemplate jmsTemplate

For recieved messages, we use: @JmsListener:

3. SpringBoot Artemis applications

In the tutorial, we create 2 SpringBoot Artemis projects for producer/consumer:

springboot artemis - architecture

III. Practice

We create 2 SpringBoot projects {SpringBootArtemisProducer, SpringBootArtemisConsumer}:

springboot artemis - project structures

Step to do:
– Create SpringBoot projects
– Implement Artemis Producer/Consumer
– Deploy Artemis
– Run and check results

1. Create SpringBoot projects

Using SpringToolSuite, we create 2 SpringBoot projects: {SpringBootArtemisProducer, SpringBootArtemisConsumer}.

For SpringBootArtemisProducer, add dependencies:

For SpringBootArtemisConsumer, add dependencies:

Why we don’t use artemis-jms-client 2.1.0 for SpringBootArtemisProducer?
-> At the time we do the tutorial, artemis-jms-client 2.1.0 has a bug for jmsTemplate.convertAndSend with exception:

Why we don’t use spring-boot-starter-artemis - version 1.5.6 (that includes artemis-jms-client 1.5.5) for Artemis consumer @JmsListener?
-> Because we got an bug:

Note:

EQUAL TO:

2. Implement Artemis Producer/Consumer

For above projects, open application.properties files, add Artemis configuration:

2.1 Implement Artemis Producer

Using JmsTemplate to implement ArtemisProducer:

– Create a simple RestApi for sending messages:

2.2 Implement Artemis Consumer

Using @JmsListener to implement ArtemisConsumer:

3. Deploy Artemis

Go to Artemis download page. Download Artemis 2.1.0:

Extract apache-artemis-2.1.0-bin.zip, we have:

springboot artemis - extract

Create an Artemis broker jsa-springboot-broker by commandline:
C:\apache-artemis-2.1.0\bin>artemis create "C:\dev\jsa-springboot-broker":

springboot artemis - create artemis broker

Run the Artemis broker by commnandline: "C:\dev\jsa-springboot-broker\bin\artemis" run

springboot artemis - run

4. Run and check results

Build and Run above SpringBoot projects with commandlines: {mvn clean install, mvn spring-boot:run}

– Make a sending request: http://localhost:8080/produce?msg=JSA - SpringBoot Artemis, Hello World!. Results:

-> Use jconsole.exe, monitor message added in Artemis queue:

springboot artemis - monitoring message

-> Artemis Consumer’s Logs:

IV. Sourcecode

SpringBootArtemisProducer
SpringBootArtemisConsumer


Related Posts


1 thought on “Apache Artemis – How to produce/consume JMS messages with SpringBoot Artemis applications.”

  1. hello.., great tutorial. Can you do complete end to end series on spring boot, spring data, angular with microservices
    It will be really helpful

Got Something To Say:

Your email address will not be published. Required fields are marked *

*