All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.cacheonix.impl.RequestDispatcherImpl Maven / Gradle / Ivy

Go to download

Cacheonix is an open source distributed cache for Java that allows its users to scale Java applications in a cluster while preserving the simplicity of design and coding in a single Java VM.

There is a newer version: 2.3.1
Show newest version
/*
 * Cacheonix Systems licenses this file to You under the LGPL 2.1
 * (the "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *      http://www.cacheonix.org/products/cacheonix/license-lgpl-2.1.htm
 *
 * 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.cacheonix.impl;

import org.cacheonix.ShutdownException;
import org.cacheonix.impl.net.processor.Message;
import org.cacheonix.impl.net.processor.Router;
import org.cacheonix.impl.net.tcp.RequestDispatcher;
import org.cacheonix.impl.util.exception.ExceptionUtils;
import org.cacheonix.impl.util.logging.Logger;

/**
 * Temporarily request dispatcher to handle TCP requests until we added channels.
 *
 * @noinspection NonStaticInnerClassInSecureContext
 */
final class RequestDispatcherImpl implements RequestDispatcher {

   /**
    * @noinspection UNUSED_SYMBOL, UnusedDeclaration
    */
   private static final Logger LOG = Logger.getLogger(RequestDispatcherImpl.class); // NOPMD

   private final Router router;


   RequestDispatcherImpl(final Router router) {

      this.router = router;
   }


   public void dispatch(final Message message) {

      try {

         router.route(message);
      } catch (final ShutdownException e) {

         // Cluster processor has already been shutdown. Ignore the request
         // to dispatch the message because our shutdown will follow shortly.
         // The message is usually a response to our last marker.
         ExceptionUtils.ignoreException(e, "Shutdown in progress");
      }
   }


   public String toString() {

      return "TCPRequestDispatcherImpl{" +
              '}';
   }
}





© 2015 - 2024 Weber Informatics LLC | Privacy Policy