- 浏览: 599301 次
- 性别:
- 来自: 厦门
文章分类
- 全部博客 (669)
- oracle (36)
- java (98)
- spring (48)
- UML (2)
- hibernate (10)
- tomcat (7)
- 高性能 (11)
- mysql (25)
- sql (19)
- web (42)
- 数据库设计 (4)
- Nio (6)
- Netty (8)
- Excel (3)
- File (4)
- AOP (1)
- Jetty (1)
- Log4J (4)
- 链表 (1)
- Spring Junit4 (3)
- Autowired Resource (0)
- Jackson (1)
- Javascript (58)
- Spring Cache (2)
- Spring - CXF (2)
- Spring Inject (2)
- 汉字拼音 (3)
- 代理模式 (3)
- Spring事务 (4)
- ActiveMQ (6)
- XML (3)
- Cglib (2)
- Activiti (15)
- 附件问题 (1)
- javaMail (1)
- Thread (19)
- 算法 (6)
- 正则表达式 (3)
- 国际化 (2)
- Json (3)
- EJB (3)
- Struts2 (1)
- Maven (7)
- Mybatis (7)
- Redis (8)
- DWR (1)
- Lucene (2)
- Linux (73)
- 杂谈 (2)
- CSS (13)
- Linux服务篇 (3)
- Kettle (9)
- android (81)
- protocol (2)
- EasyUI (6)
- nginx (2)
- zookeeper (6)
- Hadoop (41)
- cache (7)
- shiro (3)
- HBase (12)
- Hive (8)
- Spark (15)
- Scala (16)
- YARN (3)
- Kafka (5)
- Sqoop (2)
- Pig (3)
- Vue (6)
- sprint boot (19)
- dubbo (2)
- mongodb (2)
最新评论
注意事项hibernate配置文件必须设置自动提交否则不能插入成功
配置文件
监听类
消息发送类
配置文件
<?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:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" 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/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd"> <!-- 配置activeMQ --> <bean id="jmsFactory" class="org.apache.activemq.ActiveMQConnectionFactory"> <property name="brokerURL" value="tcp://localhost:61616" /> <property name="userName" value="system" /> <property name="password" value="manager" /> </bean> <!-- queue目的地配置 --> <bean id="destination" class="org.apache.activemq.command.ActiveMQQueue"> <constructor-arg index="0" value="spring-queue" /> </bean> <!-- topic目的地配置,其实不管是topic还是queue则他们的底层实现不同但是通过封装api就差不多了,而在spring中更是简单 --> <bean id="destinationTopic" class="org.apache.activemq.command.ActiveMQTopic"> <constructor-arg index="0" value="spring-topic" /> </bean> <!-- spring 使用jmsTemplate来实现消息的发送和接受 --> <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate"> <property name="connectionFactory" ref="jmsFactory"></property> <property name="defaultDestination" ref="destinationTopic"></property> <!--pubSubDomain设置true则是Topic模式 false则是queue模式 --> <property name="pubSubDomain" value="true"/> </bean> <!--异步监听 --> <bean id="myMessageListener" class="xxx.activemq.MyMessageListener"> <property name="commonDao"> <ref bean="commonDao" /> </property> </bean> <!-- 主题监听容器 {Topic模式} --> <bean id="jmsContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer" lazy-init="false"> <property name="connectionFactory" ref="jmsFactory" /> <property name="destination" ref="destinationTopic" /> <property name="messageListener" ref="myMessageListener" /> <property name="receiveTimeout" value="1000000" /> </bean> </beans>
监听类
public class MyMessageListener implements MessageListener { private static final Log LOG = LogFactory.getLog(MyMessageListener.class); private CommonDao commonDao; public CommonDao getCommonDao() { return commonDao; } public void setCommonDao(CommonDao commonDao) { this.commonDao = commonDao; } @SuppressWarnings("all") public void onMessage(Message arg0) { try { ObjectMessage message =(ObjectMessage) arg0; System.out.println(message); if(message != null){ HashMap msg = (HashMap)message.getObject(); this.handleMessage(msg.get("MSGBODY"), (String)msg.get("HANDLETYPE")); LOG.info("ActiveMQ成功处理一条数据!类名---->"+msg.get("CLASSNAME")); } } catch (Exception e) { e.printStackTrace(); } } private void handleMessage(Object obj,String type){ if(obj == null || type == null){ LOG.error("ActiveMQ处理的消息体不能为空或处理类型不能为空!"); throw new NullPointerException("ActiveMQ处理的消息体不能为空!"); } if(HANDLETYPE.ADD.toString().equals(type)){ this.commonDao.save(obj); } if(HANDLETYPE.UPDATE.toString().equals(type)){ this.commonDao.update(obj); } if(HANDLETYPE.DELETE.toString().equals(type)){ this.commonDao.delete(obj); } } } enum HANDLETYPE{ ADD,UPDATE,DELETE }
消息发送类
@Service("activemqMessageService") @SuppressWarnings("all") public class ActivemqMessageServiceImpl implements ActivemqMessageService{ private static final Log log = LogFactory.getLog(DataProviderServiceImpl.class); @Resource private JmsTemplate jmsTemplate; @Override public void sendMessage(Object msgObj,String handleType,String className){ String destination = jmsTemplate.getDefaultDestination().toString(); final HashMap<String, Object> map = new HashMap<String, Object>(); map.put("HANDLETYPE", handleType); map.put("MSGBODY", msgObj); map.put("CLASSNAME", className); System.out.println("向队列" +destination+ "发送了消息------------" + map); jmsTemplate.send(new MessageCreator() { public Message createMessage(Session session) throws JMSException { return session.createObjectMessage(map); } }); } }
发表评论
文章已被作者锁定,不允许评论。
-
java WeakHashMap学习(key是弱引用)
2018-06-21 09:31 1232在Java集合中有一种特殊的Map类型:WeakHashMap ... -
java HashMap TreeMap(key顺序) LinkedHashMap(插入顺序)学习
2018-06-07 10:27 953java为数据结构中的映射定义了一个接口java.util.M ... -
java RESTful 详解
2018-04-27 11:35 643(1)每一个URI代表一种资源,独一无二; (2)客户端 ... -
java 通过HttpsUrlConnection访问接口数据
2018-04-19 11:25 990server: ssl: key-stor ... -
java 使用多线程的场景总结
2018-04-10 14:35 1704在一个高并发的网站中,多线程是必不可少的。下面先说一下多线程在 ... -
java Enum枚举设置
2018-04-10 10:55 480/** * 数据状态:0:无效,1:有效 **/ ... -
java RestTemplate访问restful服务
2018-03-01 15:02 1621REST的基础知识 当谈论REST时,有一种常见的错误就是将其 ... -
java FYOpenApi实现短信发送
2018-01-02 17:10 11741.配置文件 sms.OpenUrl = http://s ... -
java JSONObject序列化包含Date类型数据的Java对象
2017-12-26 16:31 1617如果Date.class无法进行转换则使用Timestamp. ... -
java 用HttpsURLConnection进行传递中文时错误总结
2017-12-07 16:42 654传递中文时需要用Writer而不是OutputStream ... -
java 内存泄漏
2017-11-27 13:51 4951.内存溢出 out of memory ... -
ActiveMQ 三种发送消息方式(同步,异步,单向)
2017-11-17 10:25 2453MQ 发送普通消息有三种实现方式:可靠同步发送、可靠异步发送、 ... -
java Guava ListenableFuture实现线程回调功能
2017-11-14 10:17 1775java Future具有局限性。在实际应用中,当需要下 ... -
java Curator实现分布式锁
2017-09-05 14:39 1090Curator实现分布式锁主要依赖于zookeeper ... -
java Guava工具集学习(强大)
2017-09-05 10:28 432import java.util.Iterator ... -
java CyclicBarrier进行并发编程
2017-08-25 15:44 673CyclicBarrier允许一组线程相互等待达到一个公共的障 ... -
java 几种性能优化的总结
2017-08-23 14:08 3251、使用StringBuilder 一般 ... -
java 使用kyro进行高性能序列化对象和集合
2017-08-23 14:05 2152import java.io.ByteArrayInp ... -
ActiveMQ 传输协议总结
2017-08-23 10:48 739ActiveMQ支持的client-broker: Tran ... -
java 对重复电话号码进行排除的优化(排序和前后对比)
2017-08-22 14:14 7911.先对10万数据排序; 2.对比前后两条数据 ; 3.筛 ...
相关推荐
在这个"JMS+ActiveMQ+Spring 完整样例代码"中,我们将会探讨如何将这三者结合起来,实现一个简单的消息传递系统。以下是关键的知识点: 1. **JMS接口** JMS定义了两种主要的消息模型:点对点(Point-to-Point,P2P...
在开发中,开发者需要将ActiveMQ与C#应用程序结合,使用***框架来开发消息队列系统,这涉及到配置连接工厂、队列目的地、消息监听器容器等组件,以及编写消息消费者和生产者的代码逻辑。 在C#应用程序中使用***框架...
- **结合Spring的开发**:利用 Spring 的支持简化 ActiveMQ 的配置,并通过 Spring 管理连接和事务。 #### 五、ActiveMQ的Transport - **多种传输协议**:ActiveMQ 支持多种传输协议,如 TCP、SSL、NIO、UDP 等,每...
在分布式系统中,ActiveMQ常用于实现任务调度、事件通知和数据同步等功能,提高系统的响应速度和稳定性。 CXF是一个开源服务框架,它支持多种Web服务标准,如SOAP、RESTful等,可以方便地创建和消费Web服务。CXF...
标题中的“ActiveMQ与Zookeeper集群测试代码”指的是一个实验或示例项目,旨在演示如何结合这两个组件来构建高可用的消息传递环境。Zookeeper在这里的角色可能是用来管理ActiveMQ集群的状态,实现节点间的选举和故障...
总结来说,这个项目运用了 Java 技术栈,通过 SpringBoot 构建微服务,利用 Zookeeper 进行服务发现,借助 Dubbo 实现服务间通信,依赖 ActiveMQ 处理异步消息,以及使用 Redis 作为缓存和实现分布式锁,构建了一个...
WebSocket 和 ActiveMQ...总结来说,WebSocket和ActiveMQ的结合使用,能够为基于SpringBoot的应用提供强大的实时通信能力,实现高效的数据同步和异步任务处理。这种技术方案在金融、电商、物联网等领域有着广泛的应用。
3. **高可用性和容错**:消息中间件如ActiveMQ、RabbitMQ等,结合Spring JMS,可以构建高可用和故障切换的系统。 综上所述,Spring JMS 4.3.4.RELEASE为开发者提供了一套完整的JMS集成方案,通过抽象和封装JMS API...
在一个项目中,如果使用ActiveMQ与其他进程进行通信,当从消息队列接收到消息时,`onMessage()`方法会被触发。此时,我们可以使用Server-Sent Event将消息推送到浏览器。以下是如何实现这一目标的步骤。 首先,快速...
在物联网(IoT)场景下,Spring Cloud结合以下技术可以实现高效的数据处理和设备管理: 1. **RabbitMQ/ActiveMQ**:消息队列,用于处理物联网设备产生的大量实时数据,实现异步通信和削峰填谷。 2. **Apache Kafka**...
总结起来,这个项目展示了如何利用ActiveMQ结合Solr进行实时数据同步,同时体现了面向服务的设计思想,通过Service层封装业务逻辑,Dao层处理数据操作,以及利用Spring进行容器管理。整个流程确保了商品信息的及时...
4. **数据一致性**:由于MongoDB和MySQL的数据模型和操作方式不同,需要关注数据的一致性问题,可能需要引入事件驱动或消息队列(如RabbitMQ)来确保数据同步。 5. **安全性和监控**:配置Spring Security进行权限...
- 首先,引入对应的SpringBoot启动器依赖,如`spring-boot-starter-data-jpa`(MyBatis)、`spring-boot-starter-data-redis`(Redis)、`spring-boot-starter-activemq`(ActiveMQ)。 - 配置数据库连接、Redis...
JavaEE企业级开发面试题汇总...这些知识点构成了JavaEE企业级开发的基础,面试中通常会结合具体项目经验和实际问题进行深入探讨,以评估候选人的专业能力和实践经验。理解和掌握这些内容对于Java开发者来说至关重要。
STOMP(Simple (or Streaming) Text Oriented Messaging Protocol)是简单文本导向消息协议,是一种轻量级的网络协议,常用于与消息中间件(如RabbitMQ、Apache ActiveMQ等)进行交互。在WebSocket场景下,STOMP可以...
**JMS完全实例详解** Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用间异步通信的一种标准接口。...同时,结合Spring框架的使用,能让你更好地在实际工作中利用JMS实现高效、可靠的通信。
1. **元数据同步**:当一个新的节点加入集群时,它会同步所有现有的元数据。如果某个节点离开或出现故障,集群会自动重新分配该节点上的元数据,确保服务的连续性。 2. **集群模式的优势**:RabbitMQ 集群能够实现...
可能使用Unity或Cocos2d-x引擎,结合Java进行后端服务器开发,使用TCP/IP协议处理游戏数据传输。 10. **图书馆管理系统**:用于图书借阅、归还、查询等操作。关键技术包括条形码识别、图书分类算法、使用Spring框架...
结合Spring的JMS支持,开发者可以构建健壮、可扩展的应用,确保数据在分布式环境中的安全传输。 总的来说,基于Jboss的JMS编程涉及到Spring的集成、JNDI配置、连接工厂的创建、消息模板的使用,以及对JMS基本概念的...
- 参与舒心购电商系统项目,利用分布式架构、Dubbo、RabbitMQ等实现服务调用和缓存同步,使用Nginx进行负载均衡。 **项目经验** - 舒心购项目中,负责接口文档编写、商品信息管理、商品检索、秒杀、购物车等功能的...