项目环境:

JDK1.5
ActiveMQ5.2
所用的包都是ActiveMQ自带的。引用的包如下图:
package stujms.p2ptxt;

import org.springframework.context.ApplicationContext; 
import org.springframework.context.support.ClassPathXmlApplicationContext; 
import org.springframework.jms.core.JmsTemplate; 
import org.springframework.jms.core.MessageCreator;

import javax.jms.Destination; 
import javax.jms.JMSException; 
import javax.jms.Message; 
import javax.jms.Session;

/** 
* 消息发送者 

* @author leizhimin 2009-8-13 17:01:48 
*/ 
public class MySender { 
        public static void main(String[] args) { 
                ApplicationContext ctx = new ClassPathXmlApplicationContext("/applicationContext.xml"); 
                JmsTemplate template = (JmsTemplate) ctx.getBean("jmsTemplate"); 
                Destination destination = (Destination) ctx.getBean("destination");

template.send(destination, new MessageCreator() { 
                        public Message createMessage(Session session) throws JMSException { 
                                return session.createTextMessage("发送消息:Hello ActiveMQ Text Message!"); 
                        } 
                }); 
                System.out.println("成功发送了一条JMS消息"); 
        } 
}

package stujms.p2ptxt;

import org.springframework.context.ApplicationContext; 
import org.springframework.context.support.ClassPathXmlApplicationContext; 
import org.springframework.jms.core.JmsTemplate;

import javax.jms.Destination; 
import javax.jms.JMSException; 
import javax.jms.TextMessage;

/** 
* 消息接收者 

* @author leizhimin 2009-8-13 17:02:04 
*/ 
public class MyReceiver { 
        public static void main(String[] args) throws JMSException { 
                ApplicationContext ctx = new ClassPathXmlApplicationContext("/applicationContext.xml"); 
                JmsTemplate template = (JmsTemplate) ctx.getBean("jmsTemplate"); 
                Destination destination = (Destination) ctx.getBean("destination"); 
                while (true) { 
                        TextMessage txtmsg = (TextMessage) template.receive(destination); 
                        if (null != txtmsg) 
                                System.out.println("收到消息内容为: " + txtmsg.getText()); 
                        else 
                                break; 
                } 
        } 
}

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
             xmlns:context="http://www.springframework.org/schema/context" 
             xsi:schemaLocation="http://www.springframework.org/schema/beans 
        http://www.springframework.org/schema/beans/spring-beans-2.5.xsd 
        http://www.springframework.org/schema/context 
        http://www.springframework.org/schema/context/spring-context-2.5.xsd">

<!-- 配置JMS连接工厂 --> 
        <bean id="connectionFactory" class="org.apache.activemq.spring.ActiveMQConnectionFactory"> 
                <property name="brokerURL" value="tcp://localhost:61616"/> 
        </bean>

<!-- 配置JMS模版 --> 
        <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate"> 
                <property name="connectionFactory" ref="connectionFactory"/> 
        </bean>

<!-- 发送消息的目的地(一个队列) --> 
        <bean id="destination" class="org.apache.activemq.command.ActiveMQQueue"> 
                <!-- 设置消息队列的名字 --> 
                <constructor-arg index="0" value="HelloWorldQueue"/> 
        </bean> 
</beans>

运行发送端三次:
成功发送了一条JMS消息

Process finished with exit code 0

然后再运行接收端一次:
收到消息内容为: 发送消息:Hello ActiveMQ Text Message! 
收到消息内容为: 发送消息:Hello ActiveMQ Text Message! 
收到消息内容为: 发送消息:Hello ActiveMQ Text Message!
继续测试发现,接收端接收一条消息后不退出程序,而是继续等待,一旦有消息发送过来,就获取到,然后输出!
发一张图看看:
-----------------------------------------------------------------------------------------------------------------

1、ActiveMQ检查哪些客户端连接IP地址?

步骤:jconsole -> “ip:1099” -> Mbean -> org.apache.activemq -> localhost -> Connection -> openwire -> "具体的messageId" -> 属性 -> ‘RemoteAddress’即可看到IP地址
"具体的messageId“来源: 
jconsole -> “ip:1099” -> Mbean -> org.apache.activemq -> localhost -> "Subscription" -> "Non-Durable" -> "Queue" -> "具体的Queue名" -> 查看其下面的queue的messageId即可

2、干掉queue

通过activemq后台,http://ip:8161/admin/queues.jsp, purege或delete直接干掉

3、干掉堆积的一大堆消息

方法1:在activemq直接用delete,则会删除索引, 内容会保存在磁盘上; 同时在activemq的配置文件中,设置存活的时间, 查过时间则会自动删除磁盘上的内容。
方法2: 停掉activemq,在apache-activemq-5.2.0/data下面的内容再启动即可, 则全部的堆积消息将彻底完蛋

4、napoli从1.4.0升级到1.4.2

(1)依赖修改

  1. <dependency> <groupId>com.alibaba.shared</groupId>
  2. <artifactId>alibaba.platform.napoli</artifactId>
  3. <version>1.4.0</version> </dependency>
修改为
  1. <dependency>
  2. <groupId>com.alibaba.platform.shared</groupId>
  3. <artifactId>napoli</artifactId>
  4. <version>1.4.2</version>
  5. <type>libd</type>
  6. </dependency>
并且增加:
  1. <dependency>
  2. <groupId>com.alibaba.external</groupId>
  3. <artifactId>java.j2ee</artifactId>
  4. <version>1.4</version>
  5. </dependency>
(2)接收端代码修改
receiver.setWorker(worker);修改为 receiver.setExWorker(worker);

5、Napoli1.4.2 truck环境调试(2010-11-16)

(1)日志太大,磁盘满了, 本次干掉了部分过期的日志。将来修改为循环写的方式。
(2)activemq中存在2000多个线程,使用jstat pid > a.txt可以查看其中大量线程处于waiting状态
本文转自 tianya23 51CTO博客,原文链接:http://blog.51cto.com/tianya23/384110,如需转载请自行联系原作者

Spring2.5整合ActiveMQ 5.2(P2P文本消息)相关推荐

  1. activimq java集成_Java消息队列-Spring整合ActiveMq

    1.概述 首先和大家一起回顾一下Java 消息服务,在我之前的博客<Java消息队列-JMS概述>中,我为大家分析了: 消息服务:一个中间件,用于解决两个活多个程序之间的耦合,底层由Jav ...

  2. Java消息队列-Spring整合ActiveMq

    1.概述 首先和大家一起回顾一下Java 消息服务,在我之前的博客<Java消息队列-JMS概述>中,我为大家分析了: 消息服务:一个中间件,用于解决两个或多个程序之间的耦合,底层由Jav ...

  3. java 消息队列详解_Java消息队列-Spring整合ActiveMq的详解

    本篇文章主要介绍了详解Java消息队列-Spring整合ActiveMq ,小编觉得挺不错的,现在分享给大家,也给大家做个参考.一起跟随小编过来看看吧 1.概述 首先和大家一起回顾一下Java 消息服 ...

  4. 企业级实战02_SpringMVC整合ActiveMQ 实战需求

    SpringMVC整合ActiveMQ 文章目录 一.Spring整合ActiveMQ实战 1.1. 创建一个父工程: 1.2. 引入依赖 1.3. 创建一个子项目生产者 1.4. 创建一个sprin ...

  5. SpringBoot整合activeMQ消息队列手动签收(Session.CLIENT_ACKNOWLEDGE)为什么失效啊?

    今天在家隔离办公,不太忙,然后就琢磨起来消息队列activeMQ的消息事务来解决分布式事务,但是奈何在SpringBoot整合activeMQ时,其消费者手动签收消息时出现了问题-->当acti ...

  6. activeMQ基础学习和SpringBoot整合activeMQ案例

    昨天仔细研究了activeMQ消息队列,也遇到了些坑,昨天晚上也写了篇文章记录坑的内容,其实上篇文章(SpringBoot整合activeMQ消息队列手动签收(Session.CLIENT_ACKNO ...

  7. Spring boot整合Activemq的原理

    自动配置 如果未自定义ConnectionFactory Bean,则使用此配置.引入了ActiveMQXAConnectionFactoryConfiguration,ActiveMQConnect ...

  8. Spring整合ActiveMQ完成消息队列MQ编程

    <–start–> 第一步:新建一个maven,将工程命名为activeMQ_spring.在pom.xml文件中导入相关jar包. ①spring开发和测试相关的jar包: spring ...

  9. Spring2.5整合JPA

    在网上找了很多Spring整合JPA的文章,试着去写了很多但没有成功,主要原因可能是jar不正确导致的.花了一些时间自已写了一个小例子,Spring2.5整合JPA(Hibernate实现). 所需要 ...

  10. 实战07_SSM整合ActiveMQ支持多种类型消息

    接上一篇:企业实战06_SSM整合ActiveMQ支持多种类型消息https://blog.csdn.net/weixin_40816738/article/details/100572147 1.S ...

最新文章

  1. ubuntu中安装hadoop集群
  2. 详细讲解JAVA中的IO流
  3. linux 无法找到函数定义,找到定义Linux函数的位置
  4. a/b测试_如何进行A / B测试?
  5. Android中打包含有Activity以及资源文件的jar包在工程中调用
  6. 树莓派与node.js —— onoff、dht
  7. viturbox网卡驱动_VirtualBox Host
  8. shell 的AWK
  9. stagefright
  10. 幼儿园数学目标_幼儿园数学区目标
  11. 解决hive表中comment中文乱码问题
  12. chrome 插件--B站自动发弹幕
  13. 数据分析【实践】——教育行业指标体系搭建和生命周期维护
  14. File xxx specified for property 'resourceFile' does not exist.解决方法
  15. 华中科技大学计算机考博真题,2010年华中科技大学计算机考博试题
  16. python: 格式化字符串f()用法
  17. 小程序微信头像授权、手机号授权、地理位置授权
  18. 小时候真傻,居然盼着长大
  19. KDE设区--C++的二进制兼容问题
  20. Word制作倒福实例教程

热门文章

  1. iOS开发UI篇—控制器的创建
  2. HashMap的key可以是可变的对象吗???
  3. 【转】Javabyte[]数组和十六进制String之间的转换Util------包含案例和代码
  4. 第六届华为创新杯编程大赛第二轮(2014.4.29)
  5. linux 用户管理、权限管理
  6. Deep Learning学习随记(二)Vectorized、PCA和Whitening
  7. 像素,色彩,分辨率什么的
  8. 会议室预定模拟登陆网站
  9. sqlserver 组内排序
  10. Python数据结构之字节,字节数组