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

src.net.sf.ehcache.distribution.RMICachePeer Maven / Gradle / Ivy

There is a newer version: 4.2.4
Show newest version
/**
 *  Copyright 2003-2006 Greg Luck
 *
 *  Licensed 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
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  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 net.sf.ehcache.distribution;

import net.sf.ehcache.Ehcache;
import net.sf.ehcache.Element;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import java.io.Serializable;
import java.rmi.Remote;
import java.rmi.RemoteException;
import java.rmi.server.RMISocketFactory;
import java.rmi.server.UnicastRemoteObject;
import java.util.List;
import java.util.ArrayList;

/**
 * An RMI based implementation of CachePeer.
 * 

* This class features a customised RMIClientSocketFactory which enables socket timeouts to be configured. * * @author Greg Luck * @version $Id: RMICachePeer.java 181 2006-08-27 22:42:39Z gregluck $ * @noinspection FieldCanBeLocal */ public class RMICachePeer extends UnicastRemoteObject implements CachePeer, Remote { private static final Log LOG = LogFactory.getLog(RMICachePeer.class.getName()); private final String hostname; private final Integer port; private final Ehcache cache; /** * Construct a new remote peer. * * @param cache * @param hostName * @param port * @param socketTimeoutMillis * @throws RemoteException */ public RMICachePeer(Ehcache cache, String hostName, Integer port, Integer socketTimeoutMillis) throws RemoteException { super(0, new ConfigurableRMIClientSocketFactory(socketTimeoutMillis), RMISocketFactory.getDefaultSocketFactory()); this.hostname = hostName; this.port = port; this.cache = cache; } /** * {@inheritDoc} *

* This implementation gives an URL which has meaning to the RMI remoting system. * * @return the URL, without the scheme, as a string e.g. //hostname:port/cacheName */ public final String getUrl() { return new StringBuffer() .append("//") .append(hostname) .append(":") .append(port) .append("/") .append(cache.getName()) .toString(); } /** * {@inheritDoc} *

* This implementation gives an URL which has meaning to the RMI remoting system. * * @return the URL, without the scheme, as a string e.g. //hostname:port */ public final String getUrlBase() { return new StringBuffer() .append("//") .append(hostname) .append(":") .append(port) .toString(); } /** * Returns a list of all elements in the cache, whether or not they are expired. *

* The returned keys are unique and can be considered a set. *

* The List returned is not live. It is a copy. *

* The time taken is O(n). On a single cpu 1.8Ghz P4, approximately 8ms is required * for each 1000 entries. * * @return a list of {@link Object} keys */ public List getKeys() throws RemoteException { return cache.getKeys(); } /** * Gets an element from the cache, without updating Element statistics. Cache statistics are * still updated. * * @param key a serializable value * @return the element, or null, if it does not exist. */ public Element getQuiet(Serializable key) throws RemoteException { return cache.getQuiet(key); } /** * Gets a list of elements from the cache, for a list of keys, without updating Element statistics. Time to * idle lifetimes are therefore not affected. *

* Cache statistics are still updated. *

* Callers should ideally first call this method with a small list of keys to gauge the size of a typical Element. * Then a calculation can be made of the right number to request each time so as to optimise network performance and * not cause an OutOfMemory error on this Cache. * * @param keys a list of serializable values which represent keys * @return a list of Elements. If an element was not found or null, it will not be in the list. */ public List getElements(List keys) throws RemoteException { if (keys == null) { return new ArrayList(); } List elements = new ArrayList(); for (int i = 0; i < keys.size(); i++) { Serializable key = (Serializable) keys.get(i); Element element = cache.getQuiet(key); elements.add(element); } return elements; } /** * Puts an Element into the underlying cache without notifying listeners or updating statistics. * * @param element * @throws java.rmi.RemoteException * @throws IllegalArgumentException * @throws IllegalStateException */ public void put(Element element) throws RemoteException, IllegalArgumentException, IllegalStateException { cache.put(element, true); if (LOG.isTraceEnabled()) { LOG.trace("Remote put received. Element is: " + element); } } /** * Removes an Element from the underlying cache without notifying listeners or updating statistics. * * @param key * @return true if the element was removed, false if it was not found in the cache * @throws RemoteException * @throws IllegalStateException */ public final boolean remove(Serializable key) throws RemoteException, IllegalStateException { if (LOG.isTraceEnabled()) { LOG.trace("Remote remove received for key: " + key); } return cache.remove(key, true); } /** * Removes all cached items. * * @throws IllegalStateException if the cache is not {@link net.sf.ehcache.Status#STATUS_ALIVE} */ public final void removeAll() throws RemoteException, IllegalStateException { if (LOG.isTraceEnabled()) { LOG.trace("Remote removeAll received"); } cache.removeAll(true); } /** * Send the cache peer with an ordered list of {@link EventMessage}s *

* This enables multiple messages to be delivered in one network invocation. */ public final void send(List eventMessages) throws RemoteException { for (int i = 0; i < eventMessages.size(); i++) { EventMessage eventMessage = (EventMessage) eventMessages.get(i); if (eventMessage.getEvent() == EventMessage.PUT) { put(eventMessage.getElement()); } else if (eventMessage.getEvent() == EventMessage.REMOVE) { remove(eventMessage.getSerializableKey()); } else if (eventMessage.getEvent() == EventMessage.REMOVE_ALL) { removeAll(); } else { LOG.error("Unknown event: " + eventMessage); } } } /** * Gets the cache name */ public final String getName() throws RemoteException { return cache.getName(); } /** * {@inheritDoc} */ public final String getGuid() throws RemoteException { return cache.getGuid(); } /** * Gets the cache instance that this listener is bound to */ final Ehcache getBoundCacheInstance() { return cache; } /** * Returns a String that represents the value of this object. */ public String toString() { return getUrl(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy