org.cacheonix.impl.RequestDispatcherImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cacheonix-core Show documentation
Show all versions of cacheonix-core Show documentation
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.
/*
* 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{" +
'}';
}
}