java mq demo_中间件 activeMQ Jms Java Demo

一、什么是ActiveMQ

百度解释:

ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。

二、安装ActiveMq

windows

访问ActiveMQ官网下载ActiveMq

48ec57fbcd8095e235bba7d7ecbd1cf1.png

下载完毕后,直接解压即可,然后进入bin目录,选择运行位数(32位,64位)

1)可以点击InstallService.bat 直接启动

2)也可以点击activemq.bat 安装到window服务,每次电脑启动时就会自动启动

017cc5263c04f739778cda3e625b9821.png

fced7d1f9bbc8e939b44353a80d211f6.png

三、访问ActiveMQ

打开浏览器输入:http://127.0.0.1:8161 如下图,登录的名称和密码都是:admin

953e4f55f2ef3c9d66dfa8510743a9fe.png

011d196c6af66cb1336e72f0dcf5b1bf.png

看到上图即代表登录成功了!!!

四、编写demo代码

Maven项目

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

4.0.0

com.zy.jms

jms

1.0-SNAPSHOT

org.apache.activemq

activemq-all

5.9.0

pom.xml

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

public classAppConsumer {private static final String url = "tcp://127.0.0.1:61616";private static final String queueName = "queue_message";public static void main(String[] args) throwsJMSException {//1.创建连接工场

ConnectionFactory connectionFactory = newActiveMQConnectionFactory(url);//2.创建连接

Connection connection =connectionFactory.createConnection();//3.启动连接

connection.start();//4.创建会话

Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);//5.创建一个目标

Destination destination =session.createQueue(queueName);//6.创建消费者

MessageConsumer consumer =session.createConsumer(destination);//7.创建一个监听器

consumer.setMessageListener(newMessageListener() {public voidonMessage(Message message) {

TextMessage textMessage=(TextMessage) message;try{

System.out.println("接收消息:" +textMessage.getText());

}catch(JMSException e) {

e.printStackTrace();

}

}

});//connection.close();

}

}

AppConsumer.java

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

public classAppProducer {private static final String url = "tcp://127.0.0.1:61616";private static final String queueName = "queue_message";public static void main(String[] args) throwsJMSException {//1.创建连接工场

ConnectionFactory connectionFactory = newActiveMQConnectionFactory(url);//2.创建连接

Connection connection =connectionFactory.createConnection();//3.启动连接

connection.start();//4.创建会话

Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);//5.创建一个目标

Destination destination =session.createQueue(queueName);//6.创建生产者

MessageProducer producer =session.createProducer(destination);for (int i = 0; i < 100; i++) {//7.创建消息

TextMessage textMessage = session.createTextMessage("activeMQ" +i);

producer.send(textMessage);

}

System.out.print("所有消息已经全部发送完了");

connection.close();

}

}

AppProducer.java

五、说明

代码是演示的队列模式,还有一种是主题模式

如果要用主题模式可以修改代码码如下:

Destination destination = session.createQueue(queueName);

改为:

Destination destination = session.createTopic(topicName);

即可!!!

设置持久化:

producer.setDeliveryModel(DeliveryMode.PERSISTENT);

六、比较

队列模式:在点对点的传输方式中,消息数据被持久化,每条消息都能被消费,没有监听QUEUE地址也能被消费,数据不会丢失,一对一的发布接受策略,保证数据完整。

主题模式:在发布订阅消息方式中,消息是无状态的,不保证每条消息被消费,只有监听该TOPIC地址才能收到消息并消费,否则该消息将会丢失。一对多的发布接受策略,可以同时消费多个消息。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值