JMS_使用ActiveMQ實現消息的發送和接收

一、說明

示例中使用activeMQ-all的jar包實現jms消息的發送和接收,發送端和接收端不依賴與服務器,如果想了解使用服務器配置的方式請參照之前的jsm和MDB的文章。

注意topic消息和queue消息的區別。

二、配置

1、ActiveMQ配置

activemq-web-console的配置不再重複。

2、Maven配置

		<dependency>
			<groupId>org.apache.activemq</groupId>
			<artifactId>activemq-all</artifactId>
			<version>5.5.0</version>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-nop</artifactId>
			<version>1.6.2</version>
		</dependency>

三、發送方和接收方的代碼

1、發送方

public class AMQProducer {
	public static void main(String[] args) throws Exception {
		MessageProducer producer = null;
		Connection connection = null;
		ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://localhost:61616");
		connection = factory.createConnection();
		ActiveMQSession session = (ActiveMQSession) connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
		Queue queue = session.createQueue("myQueue2");
		producer = session.createProducer(queue);
		// Topic topic = session.createTopic("myTopic2");
		// producer = session.createProducer(topic);
		TextMessage textMessage = session.createTextMessage();
		textMessage.setText("Hello AMQ2");
		producer.send(textMessage);
		producer.close();
		connection.close();
	}
}

2、接收方

public class AMQConsumer {
	public static void main(String[] args) throws Exception {
		ActiveMQConnectionFactory connFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
		Connection conn = connFactory.createConnection();
		conn.start();
		Session session = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
		Queue queue = session.createQueue("myQueue2");
		MessageConsumer consumer = session.createConsumer(queue);
		// Topic topic = session.createTopic("myTopic2");
		// MessageConsumer consumer = session.createConsumer(topic);
		TextMessage message = (TextMessage) consumer.receive();
		String msg = message.getText();
		System.out.println(msg);
		consumer.close();
		conn.close();
	}
}



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章