如何在Activemq中订阅Java程序作为使用者?

Han*_*ath 5 java activemq-classic jms

我想Pub/Sub在项目中实现域.基本上我不是java开发人员,使用谷歌帮助.我读了这个链接.我开始实现以下结构. 在此输入图像描述

我编写了Java Application名称,MessageConsumer.java用于从AMQ代理接收消息并放置在Webserver(Apache Tomcat)中.

MessageConsumercode:

 package PackageName;
 import java.io.IOException;
 import javax.servlet.ServletException;
 import javax.servlet.http.HttpServlet;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 import javax.jms.*;
 import org.apache.activemq.ActiveMQConnectionFactory;
 public class Consumer extends HttpServlet {
 @Override
 protected void service(HttpServletRequest arg0, HttpServletResponse arg1)
    throws ServletException, IOException {
try {
//creating connectionfactory object for way
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory("admin","admin","tcp://localhost:61617");
//establishing the connection b/w this Application and Activemq
Connection connection=connectionFactory.createConnection();
Session session=connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
Topic queue=session.createTopic("MessageTesting");
javax.jms.MessageConsumer consumer=session.createConsumer(queue);
//fetching queues from Activemq
MessageListener listener = new MyListener();
consumer.setMessageListener(listener);
connection.start();
}
catch (Exception e) {
// TODO: handle exception
}
}
Run Code Online (Sandbox Code Playgroud)

}

我分别编写了另一个用于处理消息的Java应用程序(MyListener.java).

MyListener.java代码:

package PackageName;
import java.io.*;
import java.net.*;
import javax.jms.*;
public class MyListener implements MessageListener {
public void onMessage(Message msg) {
    TextMessage msg1=(TextMessage)msg;
    //just for your understanding I mention dummy code
    //System.out.println(msg1.getText());
    MyListener ml=new MyListener();
    try {

      ml.executeHttp("http://localhost:8080/ExecutableFileProcess/ClassName");
        System.out.println(msg1.getText());
    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
}}
Run Code Online (Sandbox Code Playgroud)

两个Java应用程序都在Web服务器(Apache Tomcat)中.到目前为止,我们遵循以下方式.

  1. 在向Topic发送消息之前,我们在浏览器上通过HTTP触发MessageConsumer.java.

知道,我们正在尝试什么.最初我们不想触发MessageConsumer.java.

意思是,假设MessageConsumer.java是在Webserver中.最初如果AMQ从任何地方获取消息,我们的MessageConsumer.java应该处理它们自己的逻辑.

我希望,你们明白我们在努力.

我从不工作Apache Camel,你能解释清楚吗?

谢谢.

Alp*_*iya 10

为什么你想MessageConsumer手动触发.java,因为调用Subscriber是你的ActiveMQ的负责任.

从您的主题发布您的消息到ActiveMQ服务器,订阅该主题的所有订阅者将获得您的消息,而无需手动触发它.

将此作为您的初始POC http://activemq.apache.org/hello-world.html.

您可以使用以下java代码为client2client3订阅主题

import javax.jms.*;

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

public class consumer {
    // URL of the JMS server
    private static String url = ActiveMQConnection.DEFAULT_BROKER_URL;

    // Name of the topic from which we will receive messages from = " testt"

    public static void main(String[] args) throws JMSException {
        // Getting JMS connection from the server

        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
        Connection connection = connectionFactory.createConnection();
        connection.start();

        Session session = connection.createSession(false,
                Session.AUTO_ACKNOWLEDGE);

        Topic topic = session.createTopic("testt");

        MessageConsumer consumer = session.createConsumer(topic);

        MessageListener listner = new MessageListener() {
            public void onMessage(Message message) {
                try {
                    if (message instanceof TextMessage) {
                        TextMessage textMessage = (TextMessage) message;
                        System.out.println("Received message"
                                + textMessage.getText() + "'");
                    }
                } catch (JMSException e) {
                    System.out.println("Caught:" + e);
                    e.printStackTrace();
                }
            }
        };
        consumer.setMessageListener(listner);

        try {
              System.in.read();
         } catch (IOException e) {
             e.printStackTrace();
         }
    connection.close();

}
}    
Run Code Online (Sandbox Code Playgroud)


zen*_*eni 1

你检查过阿帕奇骆驼吗? http://camel.apache.org/

您可以使用camel定义路由,以通过java代码发布和订阅代理上的主题(例如与spring bean集成)。有许多示例,包括与 activemq 消息代理交互。