You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@activemq.apache.org by cl...@apache.org on 2017/03/29 13:19:59 UTC

[1/2] activemq-artemis git commit: This closes #1134

Repository: activemq-artemis
Updated Branches:
  refs/heads/master 9df74f347 -> 3597605a6


This closes #1134


Project: http://git-wip-us.apache.org/repos/asf/activemq-artemis/repo
Commit: http://git-wip-us.apache.org/repos/asf/activemq-artemis/commit/3597605a
Tree: http://git-wip-us.apache.org/repos/asf/activemq-artemis/tree/3597605a
Diff: http://git-wip-us.apache.org/repos/asf/activemq-artemis/diff/3597605a

Branch: refs/heads/master
Commit: 3597605a605655a5af66393a41d45b10f6f8e783
Parents: 9df74f3 82c720b
Author: Clebert Suconic <cl...@apache.org>
Authored: Wed Mar 29 09:19:52 2017 -0400
Committer: Clebert Suconic <cl...@apache.org>
Committed: Wed Mar 29 09:19:52 2017 -0400

----------------------------------------------------------------------
 .../core/impl/RemotingConnectionImpl.java       |  1 +
 .../server/impl/RemotingServiceImpl.java        |  7 +-
 .../core/server/ActiveMQServerLogger.java       |  6 +-
 .../DisconnectOnCriticalFailureTest.java        | 80 ++++++++++++++++++++
 .../artemis/tests/util/JMSTestBase.java         | 24 ++++--
 5 files changed, 110 insertions(+), 8 deletions(-)
----------------------------------------------------------------------



[2/2] activemq-artemis git commit: ARTEMIS-1071 Invalid Type exception handling improvements

Posted by cl...@apache.org.
ARTEMIS-1071 Invalid Type exception handling improvements

If broker fails to decode any packets from buffer, it should
treat it as a critical bug and disconnect immediately.
Currently broker only logs an error message.


Project: http://git-wip-us.apache.org/repos/asf/activemq-artemis/repo
Commit: http://git-wip-us.apache.org/repos/asf/activemq-artemis/commit/82c720bd
Tree: http://git-wip-us.apache.org/repos/asf/activemq-artemis/tree/82c720bd
Diff: http://git-wip-us.apache.org/repos/asf/activemq-artemis/diff/82c720bd

Branch: refs/heads/master
Commit: 82c720bdfb1df4171c224dcce2442c1bab8b0990
Parents: 9df74f3
Author: Howard Gao <ho...@gmail.com>
Authored: Wed Mar 29 09:47:05 2017 +0800
Committer: Clebert Suconic <cl...@apache.org>
Committed: Wed Mar 29 09:19:52 2017 -0400

----------------------------------------------------------------------
 .../core/impl/RemotingConnectionImpl.java       |  1 +
 .../server/impl/RemotingServiceImpl.java        |  7 +-
 .../core/server/ActiveMQServerLogger.java       |  6 +-
 .../DisconnectOnCriticalFailureTest.java        | 80 ++++++++++++++++++++
 .../artemis/tests/util/JMSTestBase.java         | 24 ++++--
 5 files changed, 110 insertions(+), 8 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/activemq-artemis/blob/82c720bd/artemis-core-client/src/main/java/org/apache/activemq/artemis/core/protocol/core/impl/RemotingConnectionImpl.java
----------------------------------------------------------------------
diff --git a/artemis-core-client/src/main/java/org/apache/activemq/artemis/core/protocol/core/impl/RemotingConnectionImpl.java b/artemis-core-client/src/main/java/org/apache/activemq/artemis/core/protocol/core/impl/RemotingConnectionImpl.java
index cada061..f4efcb2 100644
--- a/artemis-core-client/src/main/java/org/apache/activemq/artemis/core/protocol/core/impl/RemotingConnectionImpl.java
+++ b/artemis-core-client/src/main/java/org/apache/activemq/artemis/core/protocol/core/impl/RemotingConnectionImpl.java
@@ -359,6 +359,7 @@ public class RemotingConnectionImpl extends AbstractRemotingConnection implement
          super.bufferReceived(connectionID, buffer);
       } catch (Exception e) {
          ActiveMQClientLogger.LOGGER.errorDecodingPacket(e);
+         throw new IllegalStateException(e);
       }
    }
 

http://git-wip-us.apache.org/repos/asf/activemq-artemis/blob/82c720bd/artemis-server/src/main/java/org/apache/activemq/artemis/core/remoting/server/impl/RemotingServiceImpl.java
----------------------------------------------------------------------
diff --git a/artemis-server/src/main/java/org/apache/activemq/artemis/core/remoting/server/impl/RemotingServiceImpl.java b/artemis-server/src/main/java/org/apache/activemq/artemis/core/remoting/server/impl/RemotingServiceImpl.java
index 3e15f3e..9a227bb 100644
--- a/artemis-server/src/main/java/org/apache/activemq/artemis/core/remoting/server/impl/RemotingServiceImpl.java
+++ b/artemis-server/src/main/java/org/apache/activemq/artemis/core/remoting/server/impl/RemotingServiceImpl.java
@@ -626,7 +626,12 @@ public class RemotingServiceImpl implements RemotingService, ServerConnectionLif
          ConnectionEntry conn = connections.get(connectionID);
 
          if (conn != null) {
-            conn.connection.bufferReceived(connectionID, buffer);
+            try {
+               conn.connection.bufferReceived(connectionID, buffer);
+            } catch (RuntimeException e) {
+               ActiveMQServerLogger.LOGGER.disconnectCritical("Error decoding buffer", e);
+               conn.connection.fail(new ActiveMQException(e.getMessage()));
+            }
          } else {
             if (logger.isTraceEnabled()) {
                logger.trace("ConnectionID = " + connectionID + " was already closed, so ignoring packet");

http://git-wip-us.apache.org/repos/asf/activemq-artemis/blob/82c720bd/artemis-server/src/main/java/org/apache/activemq/artemis/core/server/ActiveMQServerLogger.java
----------------------------------------------------------------------
diff --git a/artemis-server/src/main/java/org/apache/activemq/artemis/core/server/ActiveMQServerLogger.java b/artemis-server/src/main/java/org/apache/activemq/artemis/core/server/ActiveMQServerLogger.java
index 46a07df..b96a7a0 100644
--- a/artemis-server/src/main/java/org/apache/activemq/artemis/core/server/ActiveMQServerLogger.java
+++ b/artemis-server/src/main/java/org/apache/activemq/artemis/core/server/ActiveMQServerLogger.java
@@ -1287,6 +1287,10 @@ public interface ActiveMQServerLogger extends BasicLogger {
    @Message(id = 222217, value = "Cannot find connector-ref {0}. The cluster-connection {1} will not be deployed.", format = Message.Format.MESSAGE_FORMAT)
    void connectorRefNotFound(String connectorRef, String clusterConnection);
 
+   @LogMessage(level = Logger.Level.WARN)
+   @Message(id = 222218, value = "Server disconnecting: {0}", format = Message.Format.MESSAGE_FORMAT)
+   void disconnectCritical(String reason, @Cause Exception e);
+
 
    @LogMessage(level = Logger.Level.ERROR)
    @Message(id = 224000, value = "Failure in initialisation", format = Message.Format.MESSAGE_FORMAT)
@@ -1570,6 +1574,4 @@ public interface ActiveMQServerLogger extends BasicLogger {
    @Message(id = 224075, value = "Cannot find pageTX id = {0}", format = Message.Format.MESSAGE_FORMAT)
    void journalCannotFindPageTX(Long id);
 
-
-
 }

http://git-wip-us.apache.org/repos/asf/activemq-artemis/blob/82c720bd/tests/extra-tests/src/test/java/org/apache/activemq/artemis/tests/extras/byteman/DisconnectOnCriticalFailureTest.java
----------------------------------------------------------------------
diff --git a/tests/extra-tests/src/test/java/org/apache/activemq/artemis/tests/extras/byteman/DisconnectOnCriticalFailureTest.java b/tests/extra-tests/src/test/java/org/apache/activemq/artemis/tests/extras/byteman/DisconnectOnCriticalFailureTest.java
new file mode 100644
index 0000000..5a0d514
--- /dev/null
+++ b/tests/extra-tests/src/test/java/org/apache/activemq/artemis/tests/extras/byteman/DisconnectOnCriticalFailureTest.java
@@ -0,0 +1,80 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ * <p/>
+ * http://www.apache.org/licenses/LICENSE-2.0
+ * <p/>
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.apache.activemq.artemis.tests.extras.byteman;
+
+import org.apache.activemq.artemis.tests.util.JMSTestBase;
+import org.jboss.byteman.contrib.bmunit.BMRule;
+import org.jboss.byteman.contrib.bmunit.BMRules;
+import org.jboss.byteman.contrib.bmunit.BMUnitRunner;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+
+import javax.jms.Connection;
+import javax.jms.ExceptionListener;
+import javax.jms.JMSException;
+import javax.jms.Session;
+import java.util.concurrent.CountDownLatch;
+import java.util.concurrent.TimeUnit;
+import java.util.concurrent.atomic.AtomicBoolean;
+
+@RunWith(BMUnitRunner.class)
+public class DisconnectOnCriticalFailureTest extends JMSTestBase {
+
+   private static AtomicBoolean corruptPacket = new AtomicBoolean(false);
+
+   @Test
+   @BMRules(
+      rules = {@BMRule(
+         name = "Corrupt Decoding",
+         targetClass = "org.apache.activemq.artemis.core.protocol.core.impl.PacketDecoder",
+         targetMethod = "decode(byte)",
+         targetLocation = "ENTRY",
+         action = "org.apache.activemq.artemis.tests.extras.byteman.DisconnectOnCriticalFailureTest.doThrow();")})
+   public void testSendDisconnect() throws Exception {
+      createQueue("queue1");
+      final Connection producerConnection = nettyCf.createConnection();
+      final CountDownLatch latch = new CountDownLatch(1);
+
+      try {
+         producerConnection.setExceptionListener(new ExceptionListener() {
+            @Override
+            public void onException(JMSException e) {
+               latch.countDown();
+            }
+         });
+
+         corruptPacket.set(true);
+         producerConnection.createSession(false, Session.AUTO_ACKNOWLEDGE);
+
+         assertTrue(latch.await(5, TimeUnit.SECONDS));
+      } finally {
+         corruptPacket.set(false);
+
+         if (producerConnection != null) {
+            producerConnection.close();
+         }
+      }
+   }
+
+   public static void doThrow() {
+      if (corruptPacket.get()) {
+         corruptPacket.set(false);
+         throw new IllegalArgumentException("Invalid type: -84");
+      }
+   }
+}

http://git-wip-us.apache.org/repos/asf/activemq-artemis/blob/82c720bd/tests/integration-tests/src/test/java/org/apache/activemq/artemis/tests/util/JMSTestBase.java
----------------------------------------------------------------------
diff --git a/tests/integration-tests/src/test/java/org/apache/activemq/artemis/tests/util/JMSTestBase.java b/tests/integration-tests/src/test/java/org/apache/activemq/artemis/tests/util/JMSTestBase.java
index 196ea97..44ab399 100644
--- a/tests/integration-tests/src/test/java/org/apache/activemq/artemis/tests/util/JMSTestBase.java
+++ b/tests/integration-tests/src/test/java/org/apache/activemq/artemis/tests/util/JMSTestBase.java
@@ -59,6 +59,7 @@ public class JMSTestBase extends ActiveMQTestBase {
    protected MBeanServer mbeanServer;
 
    protected ConnectionFactory cf;
+   protected ConnectionFactory nettyCf;
    protected Connection conn;
    private final Set<JMSContext> contextSet = new HashSet<>();
    private final Random random = new Random();
@@ -130,7 +131,7 @@ public class JMSTestBase extends ActiveMQTestBase {
       Configuration config = createDefaultConfig(true).setSecurityEnabled(useSecurity()).
          addConnectorConfiguration("invm", new TransportConfiguration(INVM_CONNECTOR_FACTORY)).
          setTransactionTimeoutScanPeriod(100);
-
+      config.getConnectorConfigurations().put("netty", new TransportConfiguration(NETTY_CONNECTOR_FACTORY));
       server = addServer(ActiveMQServers.newActiveMQServer(config, mbeanServer, usePersistence()));
       jmsServer = new JMSServerManagerImpl(server);
       namingContext = new InVMNamingContext();
@@ -197,21 +198,34 @@ public class JMSTestBase extends ActiveMQTestBase {
       List<TransportConfiguration> connectorConfigs = new ArrayList<>();
       connectorConfigs.add(new TransportConfiguration(INVM_CONNECTOR_FACTORY));
 
+      List<TransportConfiguration> connectorConfigs1 = new ArrayList<>();
+      connectorConfigs1.add(new TransportConfiguration(NETTY_CONNECTOR_FACTORY));
+
       createCF(connectorConfigs, "/cf");
+      createCF("NettyCF", connectorConfigs1, "/nettyCf");
 
       cf = (ConnectionFactory) namingContext.lookup("/cf");
+      nettyCf = (ConnectionFactory)namingContext.lookup("/nettyCf");
+   }
+
+   protected void createCF(final List<TransportConfiguration> connectorConfigs,
+                           final String... jndiBindings) throws Exception {
+      createCF(name.getMethodName(), connectorConfigs, jndiBindings);
    }
 
+
    /**
-    * @param connectorConfigs
-    * @param jndiBindings
+    * @param cfName the unique ConnectionFactory's name
+    * @param connectorConfigs initial static connectors' config
+    * @param jndiBindings JNDI binding names for the CF
     * @throws Exception
     */
-   protected void createCF(final List<TransportConfiguration> connectorConfigs,
+   protected void createCF(final String cfName,
+                           final List<TransportConfiguration> connectorConfigs,
                            final String... jndiBindings) throws Exception {
       List<String> connectorNames = registerConnectors(server, connectorConfigs);
 
-      ConnectionFactoryConfiguration configuration = new ConnectionFactoryConfigurationImpl().setName(name.getMethodName()).setConnectorNames(connectorNames).setRetryInterval(1000).setReconnectAttempts(-1);
+      ConnectionFactoryConfiguration configuration = new ConnectionFactoryConfigurationImpl().setName(cfName).setConnectorNames(connectorNames).setRetryInterval(1000).setReconnectAttempts(-1);
       testCaseCfExtraConfig(configuration);
       jmsServer.createConnectionFactory(false, configuration, jndiBindings);
    }