2014-02-22 16:21:02,843 | WARN | Transport Connection to: tcp://10.18.222.21:4751 failed: java.net.SocketException: Connection reset | org.apache.activemq.broker.TransportConnection.Transport | ActiveMQ Transport: tcp:///10.18.222.21:4751@61616
2014-02-22 16:21:02,843 | WARN | Transport Connection to: tcp://127.0.0.1:4743 failed: java.net.SocketException: Connection reset | org.apache.activemq.broker.TransportConnection.Transport | ActiveMQ Transport: tcp:///127.0.0.1:4743@61616
在项目中终于解决了这个困扰很久的问题,一直想不到是这个原因,还以为MQ有BUG,
mqConnFactory = new ActiveMQConnectionFactory(config.getMqConfig().getUrl());
connection = mqConnFactory.createConnection();
当时有2个方法都使用mqConnFactory.createConnection();一个是初始化,一个是检查mq状态,mqConnFactory.createConnection();一次就行了!
以下代码是另外一个测试程序,以上面无关。
发送端:
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.Message;
import javax.jms.MessageProducer;
import javax.jms.Session;
import org.apache.activemq.ActiveMQConnectionFactory;
import org.quartz.CronScheduleBuilder;
import org.quartz.JobBuilder;
import org.quartz.JobDetail;
import org.quartz.Scheduler;
import org.quartz.SchedulerFactory;
import org.quartz.Trigger;
import org.quartz.TriggerBuilder;
import org.quartz.impl.StdSchedulerFactory;
public class MessageSendAndReceive {
public static Scheduler sched;
public static void main(String[] args) throws Exception {
MessageSendAndReceive.run();
}
public static void send() throws Exception {
ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://localhost:6