客户端采用jms(java message services) 消息中间件采用java-broker( amqp的qpid java版实现)
消息发送者代码:
package qpid.learn;
import javax.jms.Connection;
import javax.jms.Destination;
import javax.jms.Message;
import javax.jms.MessageProducer;
import javax.jms.Session;
import org.apache.qpid.client.AMQAnyDestination;
import org.apache.qpid.client.AMQConnection;
import org.apache.qpid.jms.ListMessage;
public class Sender {
public static void main(String[] args) throws Exception {
Connection conn = new AMQConnection("amqp://guest:guest@test/?brokerlist='tcp://localhost:5672'");
System.out.println(conn);
Session session = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
Destination queue = new AMQAnyDestination("ADDR:message_queue; {create: always}");
MessageProducer producer = session.createProducer(queue);
ListMessage m = ((org.apache.qpid.jms.Session)session).createListMessage();
m.setIntProperty("nsfocus", 88888888);
m.setStringProperty("nsfocus", "string");
m.setDoubleProperty("nsfocus", 0.0);
m.add("hahahahahahaha");
producer.send((Message)m);
System.out.println("sent: " + m);
conn.close();
}
}
package qpid.learn;
import javax.jms.Connection;
import javax.jms.Destination;
import javax.jms.Message;
import javax.jms.MessageProducer;
import javax.jms.Session;
import org.apache.qpid.client.AMQAnyDestination;
import org.apache.qpid.client.AMQConnection;
import org.apache.qpid.jms.ListMessage;
public class Sender {
public static void main(String[] args) throws Exception {
Connection conn = new AMQConnection("amqp://guest:guest@test/?brokerlist='tcp://localhost:5672'");
System.out.println(conn);
Session session = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
Destination queue = new AMQAnyDestination("ADDR:message_queue; {create: always}");
MessageProducer producer = session.createProducer(queue);
ListMessage m = ((org.apache.qpid.jms.Session)session).createListMessage();
m.setIntProperty("nsfocus", 88888888);
m.setStringProperty("nsfocus", "string");
m.setDoubleProperty("nsfocus", 0.0);
m.add("hahahahahahaha");
producer.send((Message)m);
System.out.println("sent: " + m);
conn.close();
}
}
消息接收者代码:
package qpid.learn;
import java.util.Iterator;
import javax.jms.Connection;
import javax.jms.Destination;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import org.apache.qpid.client.AMQAnyDestination;
import org.apache.qpid.client.AMQConnection;
import org.apache.qpid.jms.ListMessage;
public class Receiver {
public static void main(String[] args) throws Exception {
Connection connection = new AMQConnection("amqp://guest:guest@test/?brokerlist='tcp://localhost:5672'");
connection.start();
Session session = connection.createSession(false,Session.AUTO_ACKNOWLEDGE);
Destination queue = new AMQAnyDestination("ADDR:message_queue; {create: always}");
MessageConsumer consumer = session.createConsumer(queue);
ListMessage m = (ListMessage) consumer.receive();
System.out.println("Printing msg header:");
System.out.println(m);
System.out.println("Printing msg body:");
Iterator i = m.iterator();
while (i.hasNext())
System.out.println(i.next());
connection.close();
}
}
前提是必须实现启动 broker 服务
启动命令为: bin\qpid-server.bat