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.