Я не могу понять, как использовать ActiveMQ не локально.
Предположим, у меня есть 2 машины, которые должны обмениваться сообщениями.
На компьютере запускаю брокер ActiveMQ:
> ~/bin/activemq
и используйте что-то вроде:
javax.naming.Context ctx = new InitialContext();
TopicConnectionFactory factory = (TopicConnectionFactory)ctx.lookup("connectionFactory");
conn = factory.createTopicConnection();
TopicSession session = conn.createTopicSession(false,TopicSession.AUTO_ACKNOWLEDGE);
Topic topic = null;
try{
topic = (Topic)ctx.lookup("MyTopic");
System.out.println("MyTopic was found");
}catch(NameNotFoundException nnfe){
topic = session.createTopic("MyTopic");
System.out.println("MyTopic was created");
}
TextMessage textMessage = session.createTextMessage();
TopicPublisher publisher = session.createPublisher(topic);
conn.start();
textMessage.setText("My topic message number");
publisher.publish(textMessage);
System.out.println("sendMessage2topic");
где в jndi.properties у меня есть:
java.naming.factory.initial = org.apache.activemq.jndi.ActiveMQInitialContextFactory
java.naming.provider.url = tcp://localhost:61616
Но что я должен создать на другом компьютере, чтобы подписаться на эту тему? Должен ли я создать второго локального брокера ActiveMQ на 2-й машине и как подписаться на удаленную тему, которая находится на первой машине ???