Соединение JMS с Red Hat AMQ 7, работающим в Openshift по защищенному маршруту - PullRequest
0 голосов
/ 23 марта 2020

Мы запускаем AMQ 7 в Openshift 3.11. При попытке подключить java клиентов с использованием JMS с платформы Openshift проблем не возникает. Однако для доступа к нему с внешнего клиента я создал безопасный маршрут к порту 61617. В Openshift этот маршрут должен быть доступен как https://my-route: 443 , и я могу пропинговать свой маршрут. Но как я могу использовать это, чтобы установить sh соединение JMS, я продолжаю получать:

javax.jms.JMSException: Failed to create session factory
    at org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory.createConnectionInternal(ActiveMQConnectionFactory.java:886)
    at org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory.createConnection(ActiveMQConnectionFactory.java:299)
    at be.digipolis.artemis_consumer.ArtemisConsumerApplication.run(ArtemisConsumerApplication.java:39)
    at org.springframework.boot.SpringApplication.callRunner(SpringApplication.java:784)
    at org.springframework.boot.SpringApplication.callRunners(SpringApplication.java:768)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:322)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1226)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1215)
    at be.digipolis.artemis_consumer.ArtemisConsumerApplication.main(ArtemisConsumerApplication.java:25)
Caused by: ActiveMQConnectionTimedOutException[errorType=CONNECTION_TIMEDOUT message=AMQ219013: Timed out waiting to receive cluster topology. Group:null]
    at org.apache.activemq.artemis.core.client.impl.ServerLocatorImpl.createSessionFactory(ServerLocatorImpl.java:821)
    at org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory.createConnectionInternal(ActiveMQConnectionFactory.java:884)
    ... 8 more

Мой код:

Connection connection = null;
InitialContext initialContext = null;

try {
    initialContext = new InitialContext();
    Queue queue = (Queue) initialContext.lookup("queue/hugo");
    ConnectionFactory cf = (ConnectionFactory) initialContext.lookup("ConnectionFactory");
    connection = cf.createConnection(USERNAME, PASSWORD);
    Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
    MessageProducer producer = session.createProducer(queue);
    TextMessage message = session.createTextMessage("This is a text message");
    logger.info("Sent message: ", message.getText());
    producer.send(message);
    MessageConsumer consumer = session.createConsumer(queue);
    connection.start();
    TextMessage messageReceived = (TextMessage) consumer.receive(5000);
    logger.info("Received message : ", messageReceived);
    initialContext.close();
} catch (NamingException | JMSException e) {
    logger.error("Exception", e);
    e.printStackTrace();
} finally {
    if (initialContext != null) {
        initialContext.close();
    }
    if (connection != null) {
        connection.close();
    }
}

И jndi.properties:


java.naming.factory.initial=org.apache.activemq.artemis.jndi.ActiveMQInitialContextFactory
connectionFactory.ConnectionFactory=tcp://my-route:443
queue.queue/hugo=hugo

Я должен был уже использовать tcp вместо https, в противном случае я получаю "недействительный URL-адрес брокера".

Если кто-то может указать мне правильное направление, это будет здорово.

1 Ответ

0 голосов
/ 24 марта 2020

Попробуйте это:

tcp://my-route:443?httpEnabled=true&sslEnabled=true
...