ActiveMQ( 消息队列)

来源:互联网 发布:c语言实战项目开发 编辑:程序博客网 时间:2024/06/16 10:59

分析

  • MQ : Message Q (消息队列中间件)
  • ActiveMQ 是Apache旗下Java开发的开源消息中间件,完全支持
    JMS 1.1规范: Java Message Service,J2ee1.4规范,ActiveMQ相当于JMS的实现, 只要支持JMS1.1规范的工具,用法一样。
  • 支持Spring,可以很容易的内嵌到Spring

。。。。。


特点

  • 支持多语言和协议编写客户端。语言: Java, C, C++, C#, Ruby, Perl, Python, PHP。应用协议: OpenWire,Stomp REST,WS Notification,XMPP,AMQP

  • 支持多种传送协议:in-VM,TCP,SSL,NIO,UDP,JGroups,JXTA

  • 支持通过JDBC和journal提供高速的消息持久化
  • 完全支持JMS1.1和J2EE 1.4规范 (持久化,XA消息,事务)
  • 过了常见J2EE服务器(如 Geronimo,JBoss 4, GlassFish,WebLogic)的测试,其中通过JCA 1.5 resource adaptors的配置,可以让ActiveMQ可以自动的部署到任何兼容J2EE 1.4 商业服务器上
  • 从设计上保证了高性能的集群,客户端-服务器,点对点
  • 支持Ajax,支持与Axis的整合
  • 可以很容易得调用内嵌JMS provider,进行测试

消息形式

  • 点对点:即一个生产者和一个消费者一一对应
  • 发布和订阅模式:即一个生产者产生消息并进行发送后,可以由多个消费者进行接收。
  • 五种不同的消息正文格式,以及消息类型
  • treamMessage – Java原始值的数据流
      · MapMessage–一套名称-值对
      · TextMessage–一个字符串对象
      · ObjectMessage–一个序列化的 Java对象
      · BytesMessage–一个字节的数据流

安装

  • 注意ActiveMQ( 消息队列)的版本,有些版本方法会不一致

启动

./activemq startINFO: Loading '/soft/apache-activemq-5.12.0//bin/env'INFO: Using java '/soft/jdk1.7.0_55/bin/java'INFO: Starting - inspect logfiles specified in logging.properties and log4j.properties to get detailsINFO: pidfile created : '/soft/apache-activemq-5.12.0//data/activemq.pid' (pid '12992')

关闭

./activemq stop

访问

<!-- 默认端口为8161-->http://192.168.25.136:8161/   <!-- 默认登录用户和密码 都为admin-->

这里写图片描述

<!-- 如果访问Quenues和Topics报405错误,原因:这台服务器的机器名和你的IP地址没有对上,需要修改host文件-->cd /etc/hostvim /etc/hosts127.0.0.1 localhost<!-- 还不行的话或者-->vim /etc/sysconfig/networkNETWORKING=yesHOSTNAME=localhost.localdomain  <!-- 这才是真正的机器名字,再到hosts文件配置一下映射关系即可 -->重启服务即可

Demo

@Test    public void testQueueProducer() throws Exception {        //1、创建一个连接工厂对象,需要指定服务的ip及端口。        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.161:61616");        //2、使用工厂对象创建一个Connection对象。        Connection connection = connectionFactory.createConnection();        //3、开启连接,调用Connection对象的start方法。        connection.start();        //4、创建一个Session对象。        //第一个参数:是否开启事务。如果true开启事务,第二个参数无意义。一般不开启事务false。        //第二个参数:应答模式。自动应答或者手动应答。一般自动应答。        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);        //5、使用Session对象创建一个Destination对象。两种形式queue、topic,现在应该使用queue        Queue queue = session.createQueue("test-queue");        //6、使用Session对象创建一个Producer对象。        MessageProducer producer = session.createProducer(queue);        //7、创建一个Message对象,可以使用TextMessage。        /*TextMessage textMessage = new ActiveMQTextMessage();        textMessage.setText("hello Activemq");*/        TextMessage textMessage = session.createTextMessage("hello activemq");        //8、发送消息        producer.send(textMessage);        //9、关闭资源        producer.close();        session.close();        connection.close();    }    @Test    public void testQueueConsumer() throws Exception {        //创建一个ConnectionFactory对象连接MQ服务器        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.161:61616");        //创建一个连接对象        Connection connection = connectionFactory.createConnection();        //开启连接        connection.start();        //使用Connection对象创建一个Session对象        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);        //创建一个Destination对象。queue对象        Queue queue = session.createQueue("test-queue");        //使用Session对象创建一个消费者对象。        MessageConsumer consumer = session.createConsumer(queue);        //接收消息        consumer.setMessageListener(new MessageListener() {            @Override            public void onMessage(Message message) {                //打印结果                TextMessage textMessage = (TextMessage) message;                String text;                try {                    text = textMessage.getText();                    System.out.println(text);                } catch (JMSException e) {                    e.printStackTrace();                }            }        });        //等待接收消息        System.in.read();        //关闭资源        consumer.close();        session.close();        connection.close();    }
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 淘宝账号被保护要自助开通怎么办 小米平板经常出现系统无响应怎么办 淘宝买家被取消运费险了怎么办 新开的淘宝直播店没有流量怎么办 淘宝买的东西一直不发货怎么办 在淘宝上买了东西不发货怎么办 宝贝好几天拉一次吃的也少怎么办 淘宝快递正在运输途中想退货怎么办 淘宝买的东西退货商家拒收怎么办 手机屛上出现了微信图标怎么办 手机用了两年了反应太慢怎么办 魅族手机显示手机已锁定怎么办 为什么微信注册要安全验证码怎么办 微信帐号异常无法领取红包怎么办 帮朋友代付在支付宝被骗怎么办 商家说未收到货拒绝退款怎么办 淘宝商家拒绝退款怎么办还没收货的 拼多多点错确认收货了怎么办 被别人用菜刀砍伤没钱看病怎么办 东京下了订单但不发货怎么办 绑定卷皮钱包的手机号码丢了怎么办 小孩回奶在垫的被子上发霉了怎么办 2个月宝宝不喝母乳只喝奶瓶怎么办 我的扣扣被盗了朋友别被骗了怎么办 我买的股票退市了我的钱怎么办啊 在美食林被门口买宝石的骗了怎么办 在商场买的彪马鞋子皮子裂了怎么办 手机换号了京东钱包里的余额怎么办 寄报销发票给顺丰快递搞丢了怎么办 物流显示揽件但把快递弄丢了怎么办 在李宁商城上买的东西丢了怎么办 我的货发物流都过了好几天怎么办 运动鞋子买小了一码有些挤脚怎么办 媳妇先动手打我我又打媳妇了怎么办 京东商城买个电视没验收破了怎么办 钱充给波克城市游戏还不能玩怎么办 我的魅族账号密保问题忘记了怎么办 在手机店买手机买贵了被骗了怎么办 信翼4g上网宝登录密码忘了怎么办 信翼4g上网宝管理密码忘了怎么办 淘宝上买了货但店铺消失了怎么办啊