准备:
环境:win7,Eclipse,jdk1.8
ActiveMQ版本:ActiveMQ 5.9.0 Release下载地址:http://activemq.apache.org/download-archives.html
开始:
1.下载完后进行解压,解压完找到其中的activemq-all-5.9.0.jar包.
2.Eclipse创建一个java项目,导入上面这个jar包
3.创建生产者和消费者类
生产者
package com.sinosoft.activemq; import javax.jms.Connection; import javax.jms.ConnectionFactory; import javax.jms.Destination; import javax.jms.JMSException; import javax.jms.MessageProducer; import javax.jms.Session; import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnection; import org.apache.activemq.ActiveMQConnectionFactory; public class JMSProducer { //默认连接用户名 private static final String USERNAME = ActiveMQConnection.DEFAULT_USER; //默认连接密码 private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD; //默认连接地址 private static final String BROKERURL = ActiveMQConnection.DEFAULT_BROKER_URL; //发送的消息数量 private static final int SENDNUM = 10; public static void main(String[] args) { //连接工厂 ConnectionFactory connectionFactory; //连接 Connection connection = null; //会话,接收或者发送消息的线程 Session session; //消息的目的地 Destination destination; //消息生产者 MessageProducer messageProducer; //实例化连接工厂 connectionFactory = new ActiveMQConnectionFactory(JMSProducer.USERNAME, JMSProducer.PASSWORD, JMSProducer.BROKERURL); try { //通过连接工厂获取连接 connection = connectionFactory.createConnection(); //启动连接 connection.start(); //创建session session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE); //创建一个名称为Hello World!的消息队列 destination = session.createQueue("Hello World"); //创建消息生产者 messageProducer = session.createProducer(destination); //发送消息 sendMessage(session,messageProducer); session.commit(); } catch (Exception e) { e.printStackTrace(); } finally{ if(connection != null){ try { connection.close(); } catch (JMSException e) { e.printStackTrace(); } } } } /** * 发送消息 * @param session * @param messageProducer 消息生产者 * @throws Exception */ public static void sendMessage(Session session,MessageProducer messageProducer) throws Exception{ for (int i = 0; i < JMSProducer.SENDNUM; i++) { //创建一条文本消息 TextMessage message = session.createTextMessage("activemq 发送消息:" + i); System.err.println("发送消息:activemq 发送消息:" + i); //通过消息生产者发出消息 messageProducer.send(message); } } }
消费者
package com.sinosoft.activemq; import javax.jms.Connection; import javax.jms.ConnectionFactory; import javax.jms.Destination; import javax.jms.MessageConsumer; import javax.jms.Session; import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnection; import org.apache.activemq.ActiveMQConnectionFactory; public class JMSConsumer { //默认连接用户名 private static final String USERNAME = ActiveMQConnection.DEFAULT_USER; //默认连接密码 private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD; //默认连接地址 private static final String BROKERURL = ActiveMQConnection.DEFAULT_BROKER_URL; public static void main(String[] args) { //连接工厂 ConnectionFactory connectionFactory; //连接 Connection connection = null; //会话,接收或者发送消息的线程 Session session; //消息目的地 Destination destination; //消息的消费者 MessageConsumer messageConsumer; //实例化连接工厂 connectionFactory = new ActiveMQConnectionFactory(JMSConsumer.USERNAME, JMSConsumer.PASSWORD, JMSConsumer.BROKERURL); try { //通过工厂获取连接 connection = connectionFactory.createConnection(); //启动连接 connection.start(); //创建会话 session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); //创建一个连接Hello World!的消息队列 destination = session.createQueue("Hello World"); //创建消息的消费者 messageConsumer = session.createConsumer(destination); while(true){ TextMessage textMessage = (TextMessage) messageConsumer.receive(100000); if (textMessage != null) { System.err.println("收到的消息:" + textMessage.getText()); } else { break; } } } catch (Exception e) { e.printStackTrace(); } } }
从解压的压缩包找到bin目录下的activemq.bat并运行它
结果应该如下:
然后进入红线标出来的地址,出现下面页面表示已经启动了ActiveMQ的服务
刚才运行activemq.bat成功后,默认也运行了activemq-admin.bat,所以进入地址http://localhost:8161/admin/
这时需要输入用户名和密码,都是admin,成功后会进入到以下页面
运行生产者类
控制台如下:
页面上选择queues,发现
再运行消费者类后
控制台
再看刷新Queues页面,发现
就算是点对点的消息队列发送和接收成功了.
如果将消费者类这里改为true
那么最终运行完的结果就是
总结,消息队列,任重而道远,需要慢慢探索,技术性东西都是,勤学一时,受用终身