activeMQ不参与Weblogic XA事务

时间:2015-08-28 10:24:40

标签: jms weblogic activemq spring-jms

我尝试将涉及jdbc和jms DataSource的XA事务工作在部署到Weblogic的Spring webapp中。

使用本地Atomikos TransactionManager,这是有效的 - 我在ActiveMQ中看到XA调试消息,并且东西保持一致。但是,在Weblogic中,数据库和ActiveMQ在事务上不一致。

我在Weblogic中添加了一个外部JMS服务器

JNDI初始上下文工厂:

org.apache.activemq.jndi.ActiveMQInitialContextFactory

JNDI连接网址:

tcp://localhost:61616

JNDI属性:

connectionFactoryNames=XAConnectionFactory

对于该服务器,我添加了一个ConnectionFactory(远程JNDI名称= XAConnectionFactory)。查找工作到目前为止一直很好。

在我的代码中,这就是我设置Spring JTA的方式:

@Override
   @Bean
   @Profile(AppConfig.PROFILE_WEBLOGIC)
   public JtaTransactionManager transactionManager()
   {
      WebLogicJtaTransactionManager tx = new WebLogicJtaTransactionManager();
      tx.afterPropertiesSet();

      return tx;
   }

这是我的JMS配置:

   @Bean
   @Profile(AppConfig.PROFILE_WEBLOGIC)
   public ConnectionFactory connectionFactory()
   {
      Properties props = new Properties();
      props.put(Context.INITIAL_CONTEXT_FACTORY, env.getProperty(Context.INITIAL_CONTEXT_FACTORY));
      props.setProperty(Context.PROVIDER_URL, env.getProperty(Context.PROVIDER_URL));

      try
      {
         InitialContext ctx = new InitialContext(props);
         ActiveMQXAConnectionFactory connectionFactory = (ActiveMQXAConnectionFactory) ctx
            .lookup(env.getProperty("jms.connectionFactory"));

         return connectionFactory;
      }
      catch(NamingException e)
      {
         throw new RuntimeException("XAConnectionFactory lookup failed", e);
      }
   }

   @Bean
   public DefaultJmsListenerContainerFactory jmsListenerContainerFactory() throws JMSException
   {
      DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory();
      factory.setConnectionFactory(connectionFactory());
      factory.setSessionAcknowledgeMode(Session.CLIENT_ACKNOWLEDGE);
      factory.setTransactionManager(txConfig.transactionManager());
      factory.setBackOff(new FixedBackOff());

      return factory;
   }

   @Bean(name = "jmsTemplate")
   @Override
   public JmsTemplate jmsTemplate() throws JMSException
   {
      JmsTemplate t = new JmsTemplate();
      t.setConnectionFactory(connectionFactory());
      t.setMessageTimestampEnabled(true);
      t.setMessageIdEnabled(true);

      return t;
   }

我的JMS使用者注释为:

@Transactional   
@JmsListener(destination = "test.q1")

我有什么遗失的吗?

2 个答案:

答案 0 :(得分:0)

事实证明这只能通过资源适配器工作,它不能仅通过JNDI ConnectionFactory实现。

答案 1 :(得分:0)