In this post I'm going to show how to develop simple ActiveMQ queue producer and consumer. Then I will explain step by step guide to deploy it to the JBoss FUSE server. If you do not have JBoss Fuse setup in your local PC go through in my previous blog post related to setup the JBoss Fuse. While I'm learning the stuff it gave me little bit frustration due to the lack of resources to learn this technology as a beginner. Then I though to put it as blog post so in future any one can refer the guide line.
Prerequisites
- You should have install java 1.8 to support latest jboss-fuse-6.3.0
- You should have install JBoss Developer studio
- Your PC should setup Maven installed and configured.
01) Setup the ActiveMQ queue in FUSE.
First we have to start the fuse server using fuse.bat in the "bin" folder inside the installation directory on Fuse. (In my previous post I have explain how to setup the Fuse server correctly. If you need to setup go through previous post before you continue)
Once it successfully started you can see similar interface to above figure. Then you have to type following command to configure the fabric.
fabric:create
Then you can see similar figure to below.
Then go to yellow colored link "http://localhost:8181"(which showed in above figure) it will automatically redirect to "http://localhost:8181/hawtio/login". Then provide the user name and password which you should set when you setup the Fuse.
Then Fuse will create queue for you and you can see generated queue under queue tag as show in below figure.
Now we have created the queue we need to demonstration. Then type following command on the Fuse command interface to get the ActiveMQ URI.
f
abric:cluster-list
Then you will see similar output to below.
Then you need to select the default URI related to root (Since our queue setup under root)
tcp://DESKTOP-3KNHDOV:61617
02) Develop Camel application to send data to ActiveMQ queue and read them in FUSE.
Then go to Eclipse with Fuse integration and go to File -> New -> Fuse Integration Project. Then provide name for the project. I'll provided it as "DemoActiveMq" then click next and select the JBoss Fuse run-time environment then click next. Next Interface select Start with empty project and Spring DSL as show on below figure.
Then Go to the POM.xml file and update following two tags as show on below.
<groupId>com.amq.demo</groupId>
<artifactId>amq</artifactId>These two will important when install the build jar in to Fuse if you use different names you may need to change the command according to your change names in installing the jar to Fuse server.
Remove the content inside the <beans> tag and add following content in to that.
<camelContext id="_camelContext1" xmlns="http://camel.apache.org/schema/spring">
<route id="amq_test">
<from id="_from1" uri="activemq:queue:DemoQueue"/>
<log id="_log1" message="${body}"/>
<log id="_log2" message="Finished"/>
</route>
<route id="_route1">
<from id="_from2" uri="file:///c:/work/activemq"/>
<to id="_to1" uri="activemq:queue:DemoQueue"/>
</route>
</camelContext>
<bean class="org.apache.activemq.camel.component.ActiveMQComponent" id="activemq">
<property name="brokerURL" value="tcp://DESKTOP-3KNHDOV:61617"/>
<property name="userName" value="admin"/>
<property name="password" value="admin"/>
</bean>
Note that brokerURL is the URL which we retrieved previous stage and password is the password setup in Fuse server. Final camel context will be similar to below.
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://camel.apache.org/schema/spring http://camel.apache.org/schema/spring/camel-spring.xsd">
<camelContext id="_camelContext1" xmlns="http://camel.apache.org/schema/spring">
<route id="amq_test">
<from id="_from1" uri="activemq:queue:DemoQueue"/>
<log id="_log1" message="${body}"/>
<log id="_log2" message="Finished"/>
</route>
<route id="_route1">
<from id="_from2" uri="file:///c:/work/activemq"/>
<to id="_to1" uri="activemq:queue:DemoQueue"/>
</route>
</camelContext>
<bean class="org.apache.activemq.camel.component.ActiveMQComponent" id="activemq">
<property name="brokerURL" value="tcp://DESKTOP-3KNHDOV:61617"/>
<property name="userName" value="admin"/>
<property name="password" value="admin"/>
</bean>
</beans>
mvn clean installThen you should receive similar output to below.
Then go to the Fuse command line and enter following command to install the build jar in to Fuse server. (Please note that this is based on the names I have updated in the pom.xml)
osgi:install -s mvn:com.amq.demo/amq/1.0.0-SNAPSHOT
After successful installation if you log in to the "http://localhost:8181/hawtio/" then you will be able to notice that new section added under our queue in UI. refer the below fegure.
Now we can check the flow by dropping txt file in to "C:\work\activemq" location with some sample content. I'll added below content in to the text file and drop the file in to folder.
<a>
<name>Nirmal</name>
<country>Sri Lanka</country>
</a>
Then you can see the following output as expected.