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

本文记录了在项目中遇到的一个问题,当使用定时器发送消息时,ActiveMQ频繁出现WARN级别的"Connection reset"错误。经过排查,发现问题是由于重复创建Connection导致的。解决方案是确保每个定时任务只创建一次Connection。文中提供了发送端、接收端的代码示例,以及如何设置定时任务的详细步骤。
最低0.47元/天 解锁文章


被折叠的 条评论
为什么被折叠?



