Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> ActiveMQ и SQS в одном приложении 
:(
    Опции темы
nukede
Дата 28.8.2016, 23:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 4
Регистрация: 25.10.2010

Репутация: нет
Всего: нет



Привет, 
Необходимо в рамках одного приложения использовать две очереди в ActiveMQ и одну в SQS (Amazon Web Serivces Simple Queue Service). 

С подключением и работой с каждым из сервисом проблем не возникало, однако возникла проблема при одновременном использовании вышеперечисленных сервисов. А именно, Spring создает автоматически очереди в ActiveMQ, игнорируя очередь в SQS (он создает её в ActiveMQ broker), что собственно нарушает всю работу приложения. 


Я создал конфигурационные файлы для SQS

Код

@EnableJms
@Configuration
public class JmsConfig {
    SQSConnectionFactory connectionFactory =
            SQSConnectionFactory.builder()
                    .withRegion(Region.getRegion(Regions.US_WEST_1))
                    .withAWSCredentialsProvider(new DefaultAWSCredentialsProviderChain())
                    .build();
    @Bean
    public DefaultJmsListenerContainerFactory jmsListenerContainerFactory(){
        DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory();
        factory.setConnectionFactory(this.connectionFactory);
        factory.setDestinationResolver(new DynamicDestinationResolver());
        factory.setConcurrency("3-10");
        return factory;
    }

    @Bean
    public JmsTemplate defaultJmsTemplate(){
        return new JmsTemplate(this.connectionFactory);
    }

}


И для ActiveMQ

Код

@Configuration
public class MessagingConfiguration {

    private static final String DEFAULT_BROKER_URL = "tcp://localhost:61616";


    @Bean
    public ActiveMQConnectionFactory connectionFactory(){
        ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory();
        connectionFactory.setBrokerURL(DEFAULT_BROKER_URL);
        return connectionFactory;
    }
}


Код


@Configuration
@EnableJms
public class MessagingListnerConfiguration {

    @Autowired
    ConnectionFactory connectionFactory;

    @Bean
    public DefaultJmsListenerContainerFactory jmsListenerContainerFactory() {
        DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory();
        factory.setConnectionFactory(connectionFactory);
        factory.setConcurrency("10-50");
        return factory;
    }

}



Ну и соответственно у меня есть два Listener'a, которые слушают эти очереди и используют аннотации. 

Это код ActiveMQ Listener'a
Код

@JmsListener(destination = "request.queue")
    @SendTo("response.queue")
    public String receiveRequest(Order order){
        //forward message from request to response
    }


Ну и наконец код для SQS

Код

@Override
    @JmsListener(destination = "proxies-queue")
    public void onMessage(Message message) {
        try{
            Order order = new Order(((TextMessage) message).getText());
            storeService.save(order);
        }catch (Exception e){
            e.printStackTrace();
        }
    }


Прощу прощения за некоторый беспорядок в коде, так как читаю гайды, разбираюсь в работе всего этого. Вот ещё ссылочка на приложение, может будет понятнее. 
Буду рад любой помощи smile 



PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.1042 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.