apacheActiveMQ(一)
来源:互联网 发布:淘宝外国模特 编辑:程序博客网 时间:2024/06/05 16:54
ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。
特性列表
⒈ 多种语言和协议编写客户端。语言: Java,C,C++,C#,Ruby,Perl,Python,PHP。应用协议: OpenWire,Stomp REST,WS Notification,XMPP,AMQP
⒉ 完全支持JMS1.1和J2EE 1.4规范 (持久化,XA消息,事务)
⒊ 对Spring的支持,ActiveMQ可以很容易内嵌到使用Spring的系统里面去,而且也支持Spring2.0的特性
⒋ 通过了常见J2EE服务器(如 Geronimo,JBoss 4,GlassFish,WebLogic)的测试,其中通过JCA 1.5 resource adaptors的配置,可以让ActiveMQ可以自动的部署到任何兼容J2EE 1.4 商业服务器上
⒌ 支持多种传送协议:in-VM,TCP,SSL,NIO,UDP,JGroups,JXTA
⒍ 支持通过JDBC和journal提供高速的消息持久化
⒎ 从设计上保证了高性能的集群,客户端-服务器,点对点
⒏ 支持Ajax
⒐ 支持与Axis的整合
⒑ 可以很容易得调用内嵌JMS provider,进行测试
创建一个简单的消息发布者
package com.zero.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;/** * 创建消息并发送消息 * @author samuel * */public class ActiveProducer { // 系统默认的 用户名称 用户密码 连接地址 private static final String USER_NAME = ActiveMQConnection.DEFAULT_USER; private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD; private static final String BROKE_URL = ActiveMQConnection.DEFAULT_BROKER_URL; public static void main(String[] args) { ConnectionFactory connectionFactory = null; Connection connection = null; Session session; Destination destination; MessageProducer messageProducer; try { // 实例化activemq的工厂 connectionFactory = new ActiveMQConnectionFactory(USER_NAME, PASSWORD, BROKE_URL); // 使用对象工厂创建连接对象 connection = connectionFactory.createConnection(); connection.start(); // 使用连接对象创建Session /* * @parms true: true 开始session服务 false 不需要session * @parms Session.AUTO_ACKNOWLEDGE 自动接收消息 有三种类似 */ session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE); // 创建消息队列 destination = session.createQueue("firstQueue"); // 创建消息生产者 messageProducer = session.createProducer(destination); sendMessage(session, messageProducer); session.commit(); }catch (Exception e) { e.printStackTrace(); }finally { if(null != connection) { try { connection.close(); } catch (JMSException e) { e.printStackTrace(); } } } } /** * 发送消息 * @param session * @param messageProducer * @throws JMSException */ private static void sendMessage(Session session, MessageProducer messageProducer) throws JMSException { for (int i = 0; i < 10; i++) { // 创建消息 TextMessage textMessage = session.createTextMessage("ActiveMQ 发送消息2" + i); System.out.println(textMessage); // 发送消息 messageProducer.send(textMessage); } }}
需要注意的地方:
消息发布需要开启session, 所以也要提交session. session.commit();发布完消息后需要关闭connection对象.
0 0
- apacheActiveMQ(一)
- ApacheActiveMQ安装必要条件
- 一
- 《一》
- 一
- 一
- 一...
- 一
- 一
- (一)
- 一
- 一。
- (一)
- 一
- 一
- 一
- 一
- 一
- 数据结构--深入数组
- 动态代理和静态代理
- Tiny框架 迁移到orcale上
- 解决Duilib开源库中字符&被解析成下划线的问题
- NSString获取子字符串
- apacheActiveMQ(一)
- .net Image Resize
- mysql 字符串连接 concat、gropu_concat用法
- JavaWeb之JSP
- qt creator编译opus库
- 五星填数与深度优先搜索回溯思想
- numpy初始化数组时遇到的问题
- 【Android 】Dalvik虚拟机和JVM虚拟机的区别
- 在myeclipse中如何让console最小化成一个图标