Apache Camel - очереди сообщений

В большинстве интеграционных проектов используется обмен сообщениями, так как он помогает в создании слабосвязанной архитектуры приложений. Обмен сообщениями может быть синхронным или асинхронным. JMS поддерживает обаpoint-to-point а также publish-subscribeмодели. Вы используетеQueue для точка-точка и Topicдля модели публикации-подписки. На платформе Java JMS - Java Messaging Service предоставляет интерфейс для сервера обмена сообщениями. Apache activeMQ - один из таких поставщиков JMS с открытым исходным кодом. Camel не поставляется с поставщиком JMS; однако его можно настроить для использования activeMQ. Чтобы использовать этот компонент, вам необходимо включить в свой проект следующие jar-файлы - activemq, camel-spring и camel-jms.

В следующем фрагменте кода показано, как настроить Camel для activeMQ.

<bean id = "jms" class = "org.apache.camel.component.jms.JmsComponent">
   <property name = "connectionFactory">
      <bean class="org.apache.activemq.ActiveMQConnectionFactory">
         <property name = "orderQueue" value = "tcp://localhost:61000" />
      </bean>
   </property>
</bean>

Здесь приложение Camel начнет прослушивать очередь с именем orderQueue. Сама очередь настраивается на сервере обмена сообщениями activeMQ, работающем на локальном хосте и указывающем на порт 61000. Как только это будет сделано, ваше приложение может отправлять или получать сообщения в эту очередь с любой из конечных точек, определенных в вашем приложении.

Наконец, пришло время собрать все вместе в проекте, чтобы получить более глубокое понимание того, как создаются приложения Camel.