Spring2.5整合ActiveMQ 5.2(P2P文本消息)

简介:

项目环境:

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,如需转载请自行联系原作者
相关文章
|
7月前
|
消息中间件 存储 Java
第15课: Spring Boot中集成ActiveMQ
第15课: Spring Boot中集成ActiveMQ
582 0
|
11月前
|
消息中间件 存储 Java
微服务——SpringBoot使用归纳——Spring Boot中集成ActiveMQ——ActiveMQ安装
本教程介绍ActiveMQ的安装与基本使用。首先从官网下载apache-activemq-5.15.3版本,解压后即可完成安装,非常便捷。启动时进入解压目录下的bin文件夹,根据系统选择win32或win64,运行activemq.bat启动服务。通过浏览器访问`http://127.0.0.1:8161/admin/`可进入管理界面,默认用户名密码为admin/admin。ActiveMQ支持两种消息模式:点对点(Queue)和发布/订阅(Topic)。前者确保每条消息仅被一个消费者消费,后者允许多个消费者同时接收相同消息。
408 0
微服务——SpringBoot使用归纳——Spring Boot中集成ActiveMQ——ActiveMQ安装
|
11月前
|
消息中间件 Java 微服务
微服务——SpringBoot使用归纳——Spring Boot中集成ActiveMQ——发布/订阅消息的生产和消费
本文详细讲解了Spring Boot中ActiveMQ的发布/订阅消息机制,包括消息生产和消费的具体实现方式。生产端通过`sendMessage`方法发送订阅消息,消费端则需配置`application.yml`或自定义工厂以支持topic消息监听。为解决点对点与发布/订阅消息兼容问题,可通过设置`containerFactory`实现两者共存。最后,文章还提供了测试方法及总结,帮助读者掌握ActiveMQ在异步消息处理中的应用。
512 0
|
11月前
|
消息中间件 网络协议 Java
微服务——SpringBoot使用归纳——Spring Boot中集成ActiveMQ——ActiveMQ集成
本文介绍了在 Spring Boot 中集成 ActiveMQ 的详细步骤。首先通过引入 `spring-boot-starter-activemq` 依赖并配置 `application.yml` 文件实现基本设置。接着,创建 Queue 和 Topic 消息类型,分别使用 `ActiveMQQueue` 和 `ActiveMQTopic` 类完成配置。随后,利用 `JmsMessagingTemplate` 实现消息发送功能,并通过 Controller 和监听器实现点对点消息的生产和消费。最后,通过浏览器访问测试接口验证消息传递的成功性。
780 0
|
11月前
|
消息中间件 Java API
微服务——SpringBoot使用归纳——Spring Boot中集成ActiveMQ—— JMS 和 ActiveMQ 介绍
本文介绍如何在Spring Boot中集成ActiveMQ,首先阐述了JMS(Java消息服务)的概念及其作为与具体平台无关的API在异步通信中的作用。接着说明了JMS的主要对象模型,如连接工厂、会话、生产者和消费者等,并指出JMS支持点对点和发布/订阅两种消息类型。随后重点讲解了ActiveMQ,作为Apache开源的消息总线,它完全支持JMS规范,适用于异步消息处理。最后,文章探讨了在Spring Boot中使用队列(Queue)和主题(Topic)这两种消息通信形式的方法。
386 0
|
Java BI API
spring boot 整合 itextpdf 导出 PDF,写入大文本,写入HTML代码,分析当下导出PDF的几个工具
这篇文章介绍了如何在Spring Boot项目中整合iTextPDF库来导出PDF文件,包括写入大文本和HTML代码,并分析了几种常用的Java PDF导出工具。
3898 0
spring boot 整合 itextpdf 导出 PDF,写入大文本,写入HTML代码,分析当下导出PDF的几个工具
|
消息中间件 监控 Java
您是否已集成 Spring Boot 与 ActiveMQ?
您是否已集成 Spring Boot 与 ActiveMQ?
483 0
|
消息中间件 Java Kafka
SpringBoot实用开发篇第六章(整合第三方技术,ActiveMQ,RabbitMQ,RocketMQ,Kafka)
SpringBoot实用开发篇第六章(整合第三方技术,ActiveMQ,RabbitMQ,RocketMQ,Kafka)
|
消息中间件 监控 Java
使用Spring Boot结合ActiveMQ和MQTT实现消息的发送和接收
使用Spring Boot结合ActiveMQ和MQTT实现消息的发送和接收
1362 3
|
消息中间件 Java Apache
使用Spring Boot实现与ActiveMQ的消息队列集成
使用Spring Boot实现与ActiveMQ的消息队列集成