标签:定义 schema man href 另一个 tcp hold 文件 mon
实现步骤:
1、配置发送xml,applicationContext-send.xml
- <?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">
- <context:property-placeholder location="classpath:/properties/jms.properties" />
-
-
- <bean id="myConnectionFactory"
- class="org.springframework.jms.connection.CachingConnectionFactory">
-
- <property name="sessionCacheSize" value="10" />
- <property name="targetConnectionFactory">
- <bean class="org.apache.activemq.ActiveMQConnectionFactory">
-
- <property name="brokerURL" value="${brokerUrl}" />
-
- <property name="useAsyncSend" value="true" />
- </bean>
- </property>
- </bean>
-
-
- <bean id="myDestination" class="org.apache.activemq.command.ActiveMQTopic">
-
- <constructor-arg index="0" value="${send.name}" />
- </bean>
-
-
- <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
- <property name="connectionFactory" ref="myConnectionFactory" />
- <property name="defaultDestination" ref="myDestination" />
-
- <property name="pubSubDomain" value="true" />
- <property name="receiveTimeout" value="10000" />
- </bean>
- </beans>
2、编写发送java,ActiveMQsender.java
- package com.by.activeMQ;
-
- import javax.jms.JMSException;
- import javax.jms.Message;
- import javax.jms.Session;
- import javax.jms.TextMessage;
-
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import org.springframework.jms.core.JmsTemplate;
- import org.springframework.jms.core.MessageCreator;
-
- public class ActiveMQsender {
- public static void main(String[] args) {
- @SuppressWarnings("resource")
- ApplicationContext ctx = new ClassPathXmlApplicationContext(
- "ApplicationContext/applicationContext-send.xml");
-
- JmsTemplate jmsTemplate = (JmsTemplate) ctx.getBean("jmsTemplate");
-
- jmsTemplate.send(new MessageCreator() {
- public Message createMessage(Session session) throws JMSException {
- TextMessage msg = session.createTextMessage();
-
- msg.setStringProperty("mood", "happy");
-
- msg.setText("Hello World!");
- return msg;
- }
- });
-
- System.out.println("send end");
- }
- }
3、配置接收xml,applicationContext-receive.xml
4、编写接收java,ActiveMQreceiver.java
- package com.by.activeMQ;
-
- import javax.jms.JMSException;
- import javax.jms.TextMessage;
-
- import org.springframework.jms.JmsException;
-
- public class ActiveMQreceiver {
- public void receive(TextMessage message) throws JmsException, JMSException {
- String info = "this is receiver, "
- + " mood is " + message.getStringProperty("mood") + ","
- + "say " + message.getText();
- System.out.println(info);
- }
- }
5、编写另一个接收java,ActiveMQreceiver.java
- package com.by.activeMQ;
-
- import javax.jms.JMSException;
- import javax.jms.TextMessage;
-
- import org.springframework.jms.JmsException;
-
- public class ActiveMQreceiver2 {
- public void receive(TextMessage message) throws JmsException, JMSException {
- String info = "this is receiver2,"
- + " mood is " + message.getStringProperty("mood") + ","
- + "say " + message.getText();
- System.out.println(info);
- }
- }
6、编写一个main,开启接收监听,openReceive.java
- package com.by.activeMQ;
-
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
-
- public class openReceive {
-
- public static void main(String[] args) {
- @SuppressWarnings({ "unused", "resource" })
- ApplicationContext ctx = new ClassPathXmlApplicationContext("ApplicationContext/applicationContext-receive.xml");
- while(true) {
- }
- }
-
- }
7、编写一个配置文件,jms.properties
- #send
- send.name=Topic_Mood
-
- #receive
- topic.name=Topic_Mood
- topic.clientId=client_LiLei
-
- topic2.name=Topic_Mood
- topic2.clientId=client_HanMei
-
- #url
- brokerUrl=failover:(tcp://10.0.0.232:61616)?initialReconnectDelay=1000
8、pom里面添加activeMQ的依赖
- <dependency>
- <groupId>org.apache.activemq</groupId>
- <artifactId>activemq-pool</artifactId>
- <version>5.11.1</version>
- </dependency>
- <dependency>
- <groupId>org.apache.commons</groupId>
- <artifactId>commons-pool2</artifactId>
- <version>2.3</version>
- </dependency>
- <dependency>
- <groupId>org.springframework</groupId>
- <artifactId>spring-jms</artifactId>
- <version>4.0.0.RELEASE</version>
- </dependency>
-
- <dependency>
- <groupId>org.apache.activemq</groupId>
- <artifactId>activemq-all</artifactId>
- <version>5.11.1</version>
- </dependency>
耶,运行就ok了。
发送消息的输出是这样的:
- 2016-08-05 11:27:19 [ main:0 ] - [ INFO ] Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@16011db4: startup date [Fri Aug 05 11:27:19 CST 2016]; root of context hierarchy
- 2016-08-05 11:27:19 [ main:31 ] - [ INFO ] Loading XML bean definitions from class path resource [ApplicationContext/applicationContext-send.xml]
- 2016-08-05 11:27:19 [ main:187 ] - [ INFO ] Loading properties file from class path resource [properties/jms.properties]
- 2016-08-05 11:27:19 [ main:392 ] - [ INFO ] Established shared JMS Connection: ActiveMQConnection {id=ID:MDG42V9PSU28IKA-60542-1470367639797-1:1,clientId=null,started=false}
- 2016-08-05 11:27:19 [ ActiveMQ Task-1:467 ] - [ INFO ] Successfully connected to tcp://10.0.0.232:61616
- send end
接收消息的输出是这样的:
- 2016-08-05 11:28:04 [ ActiveMQ Task-1:490 ] - [ INFO ] Successfully connected to tcp://10.0.0.232:61616
- 2016-08-05 11:28:04 [ main:498 ] - [ INFO ] Established shared JMS Connection: ActiveMQConnection {id=ID:MDG42V9PSU28IKA-60544-1470367684739-1:1,clientId=client_LiLei,started=false}
- 2016-08-05 11:28:04 [ ActiveMQ Task-1:504 ] - [ INFO ] Successfully connected to tcp://10.0.0.232:61616
- 2016-08-05 11:28:04 [ main:509 ] - [ INFO ] Established shared JMS Connection: ActiveMQConnection {id=ID:MDG42V9PSU28IKA-60544-1470367684739-3:1,clientId=client_HanMei,started=false}
- this is receiver2, mood is happy,say Hello World!
- this is receiver, mood is happy,say Hello World!
配置另一个接收者就是,把第一个接收者的配置复制,然后添加个2,再把接收类复制,添加个2,就搞定了。这种方式也适用于mongodb啊这种配置。在一个工程里面操作两个mongodb数据库。
ActiveMQ订阅模式持久化实现
标签:定义 schema man href 另一个 tcp hold 文件 mon
原文地址:http://www.cnblogs.com/austinspark-jessylu/p/7827682.html