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

com.whalin.MemCached.MemCachedClient Maven / Gradle / Ivy

There is a newer version: 3.0.2
Show newest version
/**
 * MemCached Java Client Logger
 * Copyright (c) 2007 Greg Whalin
 * All rights reserved.
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the BSD license
 *
 * This library is distributed in the hope that it will be
 * useful, but WITHOUT ANY WARRANTY; without even the implied
 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
 * PURPOSE.
 *
 * You should have received a copy of the BSD License along with this
 * library.
 *
 * @author Greg Whalin  
 * @version 2.0
 */

/*******************************************************************************
 * Copyright (c) 2009 Schooner Information Technology, Inc.
 * All rights reserved.
 * 
 * http://www.schoonerinfotech.com/
 * 
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 * 3. The name of the author may not be used to endorse or promote products
 *    derived from this software without specific prior written permission.
 * 
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 ******************************************************************************/
package com.whalin.MemCached;

import java.util.Date;
import java.util.Map;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.schooner.MemCached.AscIIClient;
import com.schooner.MemCached.AscIIUDPClient;
import com.schooner.MemCached.BinaryClient;
import com.schooner.MemCached.MemcachedItem;
import com.schooner.MemCached.TransCoder;

/**
 * Schooner light-weight memcached client. It is of higher performance than
 * other java memcached clients. The main modification is done by Xingen Wang.
*
* Instead of the InputStream and OutputStream, we choose the SocketChannel and * java.nio package to increase the performance.
* Here is an example to use schooner memcached client.
*
* Firstly, we should initialize the SockIOPool, which is a connection pool.
* *

An example of initializing using defaults:

* *
 * static {
 * 	String[] serverlist = { "server1.com:port", "server2.com:port" };
 * 
 * 	SockIOPool pool = SockIOPool.getInstance();
 * 	pool.setServers(serverlist);
 * 	pool.initialize();
 * }
 * 
* *
* Then we can create the client object.
* *

To create cache client object:

* *
 * MemCachedClient mc = new MemCachedClient();
 * 
* *

To store an object:

* *
 * MemCachedClient mc = new MemCachedClient();
 * String key = "cacheKey1";
 * Object value = SomeClass.getObject();
 * mc.set(key, value);
 * 
* *

To delete a cache entry:

* *
 * MemCachedClient mc = new MemCachedClient();
 * String key = "cacheKey1";
 * mc.delete(key);
 * 
* *

To retrieve an object from the cache:

* *
 * MemCachedClient mc = new MemCachedClient();
 * String key = "key";
 * Object value = mc.get(key);
 * 
* *

To retrieve an multiple objects from the cache

* *
 * MemCachedClient mc = new MemCachedClient();
 * String[] keys = { "key", "key1", "key2" };
 * Map<Object> values = mc.getMulti(keys);
 * 
* *

To flush all items in server(s)

* *
 * MemCachedClient mc = new MemCachedClient();
 * mc.flushAll();
 * 
* */ public class MemCachedClient { MemCachedClient client; // optional passed in classloader protected ClassLoader classLoader; // optional error handler protected ErrorHandler errorHandler; // logger public static Logger log = LoggerFactory.getLogger(MemCachedClient.class); // return codes /* * start of value line from server */ public static final String VALUE = "VALUE"; /* * start of stats line from server */ public static final String STATS = "STAT"; /* * start of item line from server */ public static final String ITEM = "ITEM"; /* * successful deletion */ public static final String DELETED = "DELETED\r\n"; /* * successful synced. */ public static final String SYNCED = "SYNCED\r\n"; /* * record not found for delete or incr/decr */ public static final String NOTFOUND = "NOT_FOUND\r\n"; /* * successful store of data */ public static final String STORED = "STORED\r\n"; /* * success */ public static final String OK = "OK\r\n"; /* * end of data from server */ public static final String END = "END\r\n"; /* * invalid command name from client */ public static final String ERROR = "ERROR\r\n"; /* * client error in input line - invalid protocol */ public static final String CLIENT_ERROR = "CLIENT_ERROR\r\n"; // default compression threshold public static final int COMPRESS_THRESH = 30720; /* * server error */ public static final String SERVER_ERROR = "SERVER_ERROR\r\n"; public static final byte[] B_RETURN = "\r\n".getBytes(); public static final byte[] B_END = "END\r\n".getBytes(); public static final byte[] B_NOTFOUND = "NOT_FOUND\r\n".getBytes(); public static final byte[] B_DELETED = "DELETED\r\r".getBytes(); public static final byte[] B_STORED = "STORED\r\r".getBytes(); /** * The following static constants are used for the binary protocol. */ public static final byte MAGIC_REQ = (byte) 0x80; public static final byte MAGIC_RESP = (byte) 0x81; public static final int F_COMPRESSED = 2; public static final int F_SERIALIZED = 8; public static final int STAT_NO_ERROR = 0x0000; public static final int STAT_KEY_NOT_FOUND = 0x0001; public static final int STAT_KEY_EXISTS = 0x0002; public static final int STAT_VALUE_TOO_BIG = 0x0003; public static final int STAT_INVALID_ARGUMENTS = 0x0004; public static final int STAT_ITEM_NOT_STORED = 0x0005; public static final int STAT_UNKNOWN_COMMAND = 0x0081; public static final int STAT_OUT_OF_MEMORY = 0x0082; public static final byte OPCODE_GET = (byte) 0x00; public static final byte OPCODE_SET = (byte) 0x01; public static final byte OPCODE_ADD = (byte) 0x02; public static final byte OPCODE_REPLACE = (byte) 0x03; public static final byte OPCODE_DELETE = (byte) 0x04; public static final byte OPCODE_INCREMENT = (byte) 0x05; public static final byte OPCODE_DECREMENT = (byte) 0x06; public static final byte OPCODE_QUIT = (byte) 0x07; public static final byte OPCODE_FLUSH = (byte) 0x08; public static final byte OPCODE_GETQ = (byte) 0x09; public static final byte OPCODE_NOOP = (byte) 0x0A; public static final byte OPCODE_VERSION = (byte) 0x0B; public static final byte OPCODE_GETK = (byte) 0x0C; public static final byte OPCODE_GETKQ = (byte) 0x0D; public static final byte OPCODE_APPEND = (byte) 0x0E; public static final byte OPCODE_PREPEND = (byte) 0x0F; public static final byte OPCODE_STAT = (byte) 0x10; public static final byte OPCODE_AUTH_LIST = (byte) 0x20; public static final byte OPCODE_START_AUTH = (byte) 0x21; public static final byte OPCODE_AUTH_STEPS = (byte) 0x22; public static final byte AUTH_FAILED = 0x20; public static final byte FURTHER_AUTH = 0x21; /** * This is used for set command only.
* The reason for use this that we have to put the size of the object bytes * into the command line. While as a matter of fact, we can't get the real * size before we completed the serialization.
* In order to solve this problem, we add this blank area to the size * position in the command line. When we complete the full serialization and * get the bytes size, we will replace this blank are with real bytes size.
* This definitely help us decrease the GC of JVM. */ public final byte[] BLAND_DATA_SIZE = " ".getBytes(); /** * values for cache flags */ public static final int MARKER_BYTE = 1; public static final int MARKER_BOOLEAN = 8192; public static final int MARKER_INTEGER = 4; public static final int MARKER_LONG = 16384; public static final int MARKER_CHARACTER = 16; public static final int MARKER_STRING = 32; public static final int MARKER_STRINGBUFFER = 64; public static final int MARKER_FLOAT = 128; public static final int MARKER_SHORT = 256; public static final int MARKER_DOUBLE = 512; public static final int MARKER_DATE = 1024; public static final int MARKER_STRINGBUILDER = 2048; public static final int MARKER_BYTEARR = 4096; public static final int MARKER_OTHERS = 0x00; public boolean isUseBinaryProtocol() { return client.isUseBinaryProtocol(); } /** * used when you want to create a ASCIIClient/BinaryClient/UDPASCIIClient * instance */ protected MemCachedClient(MemCachedClient client) { this.client = client; } /** * Creates a new instance of MemCachedClient. */ public MemCachedClient() { this(null, true, false); } /** * Creates a new instance of MemCachedClient.
* Use binary protocol with TCP. * * @param binaryProtocal * whether use binary protocol. */ public MemCachedClient(boolean binaryProtocal) { this(null, true, binaryProtocal); } /** * Creates a new instance of MemCachedClient accepting a passed in pool * name. * * @param poolName * name of SockIOPool */ public MemCachedClient(String poolName) { this(poolName, true, false); } /** * Creates a new instance of MemCachedClient accepting a passed in pool * name. * * @param poolName * name of SockIOPool * @param binaryProtocal * whether use binary protocol. */ public MemCachedClient(String poolName, boolean binaryProtocal) { this(poolName, true, binaryProtocal); } /** * Create default memcached client. * * @param isTCP * true - use tcp protocol
* false - use udp protocol * @param binaryProtocal * use binary protocol. */ public MemCachedClient(boolean isTCP, boolean binaryProtocal) { this(null, isTCP, binaryProtocal); } /** * Create memcached client. * * @param poolName * name of SockIOPool * @param isTCP * use tcp protocol * @param binaryProtocal * use binary protocol. */ public MemCachedClient(String poolName, boolean isTcp, boolean binaryProtocal) { if (binaryProtocal) client = new BinaryClient(poolName); else client = isTcp ? new AscIIClient(poolName) : new AscIIUDPClient(poolName); } /** * create memcached client. * * @param poolName * pool name * @param isTcp * is tcp protocol? * @param binaryProtocol * is binary protocol? * @param cl * classloader. * @param eh * errorhandler. * @deprecated will be removed in next release.
* Please use customized transcoder * {@link com.schooner.MemCached.AbstractTransCoder} to achieve * the same objective. */ public MemCachedClient(String poolName, boolean isTcp, boolean binaryProtocol, ClassLoader cl, ErrorHandler eh) { if (binaryProtocol) client = new BinaryClient(poolName, cl, eh); else client = isTcp ? new AscIIClient(poolName, cl, eh) : new AscIIUDPClient(poolName, cl, eh); } /** * Creates a new instance of MemCacheClient but acceptes a passed in * ClassLoader. * * @param classLoader * ClassLoader object. * @deprecated will be removed in next release.
* Please use customized transcoder * {@link com.schooner.MemCached.AbstractTransCoder} to achieve * the same objective. */ public MemCachedClient(ClassLoader classLoader) { this(); client.setClassLoader(classLoader); } /** * Creates a new instance of MemCacheClient but acceptes a passed in * ClassLoader and a passed in ErrorHandler. * * @param classLoader * ClassLoader object. * @param errorHandler * ErrorHandler object. * @deprecated will be removed in next release.
* Please use customized transcoder * {@link com.schooner.MemCached.AbstractTransCoder} to achieve * the same objective. */ public MemCachedClient(ClassLoader classLoader, ErrorHandler errorHandler) { this(null, true, false, classLoader, errorHandler); } /** * Creates a new instance of MemCacheClient but acceptes a passed in * ClassLoader, ErrorHandler, and SockIOPool name. * * @param classLoader * ClassLoader object. * @param errorHandler * ErrorHandler object. * @param poolName * SockIOPool name * @deprecated will be removed in next release.
* Please use customized transcoder * {@link com.schooner.MemCached.AbstractTransCoder} to achieve * the same objective. */ public MemCachedClient(ClassLoader classLoader, ErrorHandler errorHandler, String poolName) { this(poolName, true, false, classLoader, errorHandler); } /** * Sets an optional ClassLoader to be used for serialization. * * @param classLoader * @deprecated will be removed in next release.
* Please use customized transcoder * {@link com.schooner.MemCached.AbstractTransCoder} to achieve * the same objective. */ public void setClassLoader(ClassLoader classLoader) { throw new UnsupportedOperationException(); } /** * Sets an optional ErrorHandler. * * @param errorHandler * @deprecated will be removed in next release. The purpose of adding this * support was to make it compatible with previous releases. */ public void setErrorHandler(ErrorHandler errorHandler) { throw new UnsupportedOperationException(); } /** * Enable storing compressed data, provided it meets the threshold * requirements. * * If enabled, data will be stored in compressed form if it is
* longer than the threshold length set with setCompressThreshold(int)
*
* The default is that compression is enabled.
*
* Even if compression is disabled, compressed data will be automatically
* decompressed. * * @param compressEnable * true to enable compression, false to * disable compression * @deprecated will be removed in next release. */ public void setCompressEnable(boolean compressEnable) { throw new UnsupportedOperationException(); } /** * Sets the required length for data to be considered for compression. * * If the length of the data to be stored is not equal or larger than this * value, it will not be compressed. * * This defaults to 15 KB. * * @param compressThreshold * required length of data to consider compression * @deprecated will be removed in next release. */ public void setCompressThreshold(long compressThreshold) { throw new UnsupportedOperationException(); } /** * Sets default String encoding when storing primitives as Strings. Default * is UTF-8. * * @param defaultEncoding */ public void setDefaultEncoding(String defaultEncoding) { client.setDefaultEncoding(defaultEncoding); } /** * Enables storing primitive types as their String values. * * @param primitiveAsString * if true, then store all primitives as their string value. */ public void setPrimitiveAsString(boolean primitiveAsString) { client.setPrimitiveAsString(primitiveAsString); } /** * Enables/disables sanitizing keys by URLEncoding. * * @param sanitizeKeys * if true, then URLEncode all keys */ public void setSanitizeKeys(boolean sanitizeKeys) { client.setSanitizeKeys(sanitizeKeys); } /** * Checks to see if key exists in cache. * * @param key * the key to look for * @return true if key found in cache, false if not (or if cache is down) */ public boolean keyExists(String key) { return client.keyExists(key); } /** * Deletes an object from cache given cache key. * * @param key * the key to be removed * @return true, if the data was deleted successfully */ public boolean delete(String key) { return client.delete(key); } /** * Deletes an object from cache given cache key and expiration date. * * @deprecated not supported in memcached 1.4+ * @param key * the key to be removed * @param expiry * when to expire the record. * @return true, if the data was deleted successfully */ public boolean delete(String key, Date expiry) { return client.delete(key, expiry); } /** * Deletes an object from cache given cache key, a delete time, and an * optional hashcode. * * The item is immediately made non retrievable.
* Keep in mind {@link #add(String, Object) add} and * {@link #replace(String, Object) replace}
* will fail when used with the same key will fail, until the server reaches * the
* specified time. However, {@link #set(String, Object) set} will succeed,
* and the new value will not be deleted. * * @deprecated not supported in memcached 1.4+ * @param key * the key to be removed * @param hashCode * if not null, then the int hashcode to use * @param expiry * when to expire the record. * @return true, if the data was deleted successfully */ public boolean delete(String key, Integer hashCode, Date expiry) { return client.delete(key, hashCode, expiry); } /** * Stores data on the server; only the key and the value are specified. * * @param key * key to store data under * @param value * value to store * @return true, if the data was successfully stored */ public boolean set(String key, Object value) { return client.set(key, value); } /** * Stores data on the server; only the key and the value are specified. * * @param key * key to store data under * @param value * value to store * @param hashCode * if not null, then the int hashcode to use * @return true, if the data was successfully stored */ public boolean set(String key, Object value, Integer hashCode) { return client.set(key, value, hashCode); } /** * Stores data on the server; the key, value, and an expiration time are * specified. * * @param key * key to store data under * @param value * value to store * @param expiry * when to expire the record * @return true, if the data was successfully stored */ public boolean set(String key, Object value, Date expiry) { return client.set(key, value, expiry); } /** * Stores data on the server; the key, value, and an expiration time are * specified. * * @param key * key to store data under * @param value * value to store * @param expiry * when to expire the record * @param hashCode * if not null, then the int hashcode to use * @return true, if the data was successfully stored */ public boolean set(String key, Object value, Date expiry, Integer hashCode) { return client.set(key, value, expiry, hashCode); } /** * Adds data to the server; only the key and the value are specified. * * @param key * key to store data under * @param value * value to store * @return true, if the data was successfully stored */ public boolean add(String key, Object value) { return client.add(key, value); } /** * Adds data to the server; the key, value, and an optional hashcode are * passed in. * * @param key * key to store data under * @param value * value to store * @param hashCode * if not null, then the int hashcode to use * @return true, if the data was successfully stored */ public boolean add(String key, Object value, Integer hashCode) { return client.add(key, value, hashCode); } /** * Adds data to the server; the key, value, and an expiration time are * specified. * * @param key * key to store data under * @param value * value to store * @param expiry * when to expire the record * @return true, if the data was successfully stored */ public boolean add(String key, Object value, Date expiry) { return client.add(key, value, expiry); } /** * Adds data to the server; the key, value, and an expiration time are * specified. * * @param key * key to store data under * @param value * value to store * @param expiry * when to expire the record * @param hashCode * if not null, then the int hashcode to use * @return true, if the data was successfully stored */ public boolean add(String key, Object value, Date expiry, Integer hashCode) { return client.add(key, value, expiry, hashCode); } /** * Updates data on the server; only the key and the value are specified. * * @param key * key to store data under * @param value * value to store * @return true, if the data was successfully stored */ public boolean replace(String key, Object value) { return client.replace(key, value); } /** * Updates data on the server; only the key and the value and an optional * hash are specified. * * @param key * key to store data under * @param value * value to store * @param hashCode * if not null, then the int hashcode to use * @return true, if the data was successfully stored */ public boolean replace(String key, Object value, Integer hashCode) { return client.replace(key, value, hashCode); } /** * Updates data on the server; the key, value, and an expiration time are * specified. * * @param key * key to store data under * @param value * value to store * @param expiry * when to expire the record * @return true, if the data was successfully stored */ public boolean replace(String key, Object value, Date expiry) { return client.replace(key, value, expiry); } /** * Updates data on the server; the key, value, and an expiration time are * specified. * * @param key * key to store data under * @param value * value to store * @param expiry * when to expire the record * @param hashCode * if not null, then the int hashcode to use * @return true, if the data was successfully stored */ public boolean replace(String key, Object value, Date expiry, Integer hashCode) { return client.replace(key, value, expiry, hashCode); } /** * Store a counter to memcached given a key * * @param key * cache key * @param counter * number to store * @return true/false indicating success */ public boolean storeCounter(String key, Long counter) { return storeCounter(key, counter, null, null); } /** * Store a counter to memcached given a key * * @param key * cache key * @param counter * number to store * @param date * when to expire the record * @return true/false indicating success */ public boolean storeCounter(String key, Long counter, Date date) { return storeCounter(key, counter, date, null); } /** * Store a counter to memcached given a key * * @param key * cache key * @param counter * number to store * @param date * when to expire the record * @param hashCode * if not null, then the int hashcode to use * @return true/false indicating success */ public boolean storeCounter(String key, Long counter, Date date, Integer hashCode) { return set(key, counter, date, hashCode); } /** * Store a counter to memcached given a key * * @param key * cache key * @param counter * number to store * @param hashCode * if not null, then the int hashcode to use * @return true/false indicating success */ public boolean storeCounter(String key, Long counter, Integer hashCode) { return storeCounter(key, counter, null, hashCode); } /** * Returns value in counter at given key as long. * * @param key * cache ket * @return counter value or -1 if not found */ public long getCounter(String key) { return getCounter(key, null); } /** * Returns value in counter at given key as long. * * @param key * cache ket * @param hashCode * if not null, then the int hashcode to use * @return counter value or -1 if not found */ public long getCounter(String key, Integer hashCode) { if (key == null) { if (log.isErrorEnabled()) log.error("null key for getCounter()"); return -1; } long counter = -1; try { counter = Long.parseLong((String) get(key, hashCode, true)); } catch (Exception ex) { // if we have an errorHandler, use its hook if (errorHandler != null) errorHandler.handleErrorOnGet(this, ex, key); // not found or error getting out if (log.isDebugEnabled()) log.info(String.format("Failed to parse Long value for key: %s", key)); } return counter; } /** * Thread safe way to initialize and increment a counter. * * @param key * key where the data is stored * @return value of incrementer */ public long addOrIncr(String key) { return client.addOrIncr(key); } /** * Thread safe way to initialize and increment a counter. * * @param key * key where the data is stored * @param inc * value to set or increment by * @return value of incrementer */ public long addOrIncr(String key, long inc) { return client.addOrIncr(key, inc); } /** * Thread safe way to initialize and increment a counter. * * @param key * key where the data is stored * @param inc * value to set or increment by * @param hashCode * if not null, then the int hashcode to use * @return value of incrementer */ public long addOrIncr(String key, long inc, Integer hashCode) { return client.addOrIncr(key, inc, hashCode); } /** * Thread safe way to initialize and decrement a counter. * * @param key * key where the data is stored * @return value of incrementer */ public long addOrDecr(String key) { return client.addOrDecr(key); } /** * Thread safe way to initialize and decrement a counter. * * @param key * key where the data is stored * @param inc * value to set or increment by * @return value of incrementer */ public long addOrDecr(String key, long inc) { return client.addOrDecr(key, inc); } /** * Thread safe way to initialize and decrement a counter. * * @param key * key where the data is stored * @param inc * value to set or increment by * @param hashCode * if not null, then the int hashcode to use * @return value of incrementer */ public long addOrDecr(String key, long inc, Integer hashCode) { return client.addOrDecr(key, inc, hashCode); } /** * Increment the value at the specified key by 1, and then return it.
* Please make sure setPrimitiveAsString=true if the key/value pair is * stored with set command. * * @param key * key where the data is stored * @return -1, if the key is not found, the value after incrementing * otherwise */ public long incr(String key) { return client.incr(key); } /** * Increment the value at the specified key by passed in val.
* Please make sure setPrimitiveAsString=true if the key/value pair is * stored with set command. * * @param key * key where the data is stored * @param inc * how much to increment by * @return -1, if the key is not found, the value after incrementing * otherwise */ public long incr(String key, long inc) { return client.incr(key, inc); } /** * Increment the value at the specified key by the specified increment, and * then return it.
* Please make sure setPrimitiveAsString=true if the key/value pair is * stored with set command. * * @param key * key where the data is stored * @param inc * how much to increment by * @param hashCode * if not null, then the int hashcode to use * @return -1, if the key is not found, the value after incrementing * otherwise */ public long incr(String key, long inc, Integer hashCode) { return client.incr(key, inc, hashCode); } /** * Decrement the value at the specified key by 1, and then return it.
* Please make sure setPrimitiveAsString=true if the key/value pair is * stored with set command. * * @param key * key where the data is stored * @return -1, if the key is not found, the value after incrementing * otherwise */ public long decr(String key) { return client.decr(key); } /** * Decrement the value at the specified key by passed in value, and then * return it.
* Please make sure setPrimitiveAsString=true if the key/value pair is * stored with set command. * * @param key * key where the data is stored * @param inc * how much to increment by * @return -1, if the key is not found, the value after incrementing * otherwise */ public long decr(String key, long inc) { return client.decr(key, inc); } /** * Decrement the value at the specified key by the specified increment, and * then return it.
* Please make sure setPrimitiveAsString=true if the key/value pair is * stored with set command. * * @param key * key where the data is stored * @param inc * how much to increment by * @param hashCode * if not null, then the int hashcode to use * @return -1, if the key is not found, the value after incrementing * otherwise */ public long decr(String key, long inc, Integer hashCode) { return client.decr(key, inc, hashCode); } /** * Retrieve a key from the server, using a specific hash. * * If the data was compressed or serialized when compressed, it will * automatically
* be decompressed or serialized, as appropriate. (Inclusive or)
*
* Non-serialized data will be returned as a string, so explicit conversion * to
* numeric types will be necessary, if desired
* * @param key * key where data is stored * @return the object that was previously stored, or null if it was not * previously stored */ public Object get(String key) { return client.get(key); } /** * Retrieve a key from the server, using a specific hash. * * If the data was compressed or serialized when compressed, it will * automatically
* be decompressed or serialized, as appropriate. (Inclusive or)
*
* Non-serialized data will be returned as a string, so explicit conversion * to
* numeric types will be necessary, if desired
* * @param key * key where data is stored * @param hashCode * if not null, then the int hashcode to use * @return the object that was previously stored, or null if it was not * previously stored */ public Object get(String key, Integer hashCode) { return client.get(key, hashCode); } public MemcachedItem gets(String key) { return client.gets(key); } public MemcachedItem gets(String key, Integer hashCode) { return client.gets(key, hashCode); } public void setTransCoder(TransCoder transCoder) { client.setTransCoder(transCoder); } /** * Retrieve a key from the server, using a specific hash. * * If the data was compressed or serialized when compressed, it will * automatically
* be decompressed or serialized, as appropriate. (Inclusive or)
*
* Non-serialized data will be returned as a string, so explicit conversion * to
* numeric types will be necessary, if desired
* * @param key * key where data is stored * @param hashCode * if not null, then the int hashcode to use * @param asString * if true, then return string val * @return the object that was previously stored, or null if it was not * previously stored */ public Object get(String key, Integer hashCode, boolean asString) { return client.get(key, hashCode, asString); } /** * Retrieve multiple objects from the memcache. * * This is recommended over repeated calls to {@link #get(String) get()}, * since it
* is more efficient.
* * @param keys * String array of keys to retrieve * @return Object array ordered in same order as key array containing * results */ public Object[] getMultiArray(String[] keys) { return client.getMultiArray(keys); } /** * Retrieve multiple objects from the memcache. * * This is recommended over repeated calls to {@link #get(String) get()}, * since it
* is more efficient.
* * @param keys * String array of keys to retrieve * @param hashCodes * if not null, then the Integer array of hashCodes * @return Object array ordered in same order as key array containing * results */ public Object[] getMultiArray(String[] keys, Integer[] hashCodes) { return client.getMultiArray(keys, hashCodes); } /** * Retrieve multiple objects from the memcache. * * This is recommended over repeated calls to {@link #get(String) get()}, * since it
* is more efficient.
* * @param keys * String array of keys to retrieve * @param hashCodes * if not null, then the Integer array of hashCodes * @param asString * if true, retrieve string vals * @return Object array ordered in same order as key array containing * results */ public Object[] getMultiArray(String[] keys, Integer[] hashCodes, boolean asString) { return client.getMultiArray(keys, hashCodes, asString); } /** * Retrieve multiple objects from the memcache. * * This is recommended over repeated calls to {@link #get(String) get()}, * since it
* is more efficient.
* * @param keys * String array of keys to retrieve * @return a hashmap with entries for each key is found by the server, keys * that are not found are not entered into the hashmap, but * attempting to retrieve them from the hashmap gives you null. */ public Map getMulti(String[] keys) { return getMulti(keys, null); } /** * Retrieve multiple keys from the memcache. * * This is recommended over repeated calls to {@link #get(String) get()}, * since it
* is more efficient.
* * @param keys * keys to retrieve * @param hashCodes * if not null, then the Integer array of hashCodes * @return a hashmap with entries for each key is found by the server, keys * that are not found are not entered into the hashmap, but * attempting to retrieve them from the hashmap gives you null. */ public Map getMulti(String[] keys, Integer[] hashCodes) { return client.getMulti(keys, hashCodes); } /** * Retrieve multiple keys from the memcache. * * This is recommended over repeated calls to {@link #get(String) get()}, * since it
* is more efficient.
* * @param keys * keys to retrieve * @param hashCodes * if not null, then the Integer array of hashCodes * @param asString * if true then retrieve using String val * @return a hashmap with entries for each key is found by the server, keys * that are not found are not entered into the hashmap, but * attempting to retrieve them from the hashmap gives you null. */ public Map getMulti(String[] keys, Integer[] hashCodes, boolean asString) { return client.getMulti(keys, hashCodes, asString); } /** * Invalidates the entire cache. * * Will return true only if succeeds in clearing all servers. * * @return success true/false */ public boolean flushAll() { return client.flushAll(); } /** * Invalidates the entire cache. * * Will return true only if succeeds in clearing all servers. If pass in * null, then will try to flush all servers. * * @param servers * optional array of host(s) to flush (host:port) * @return success true/false */ public boolean flushAll(String[] servers) { return client.flushAll(servers); } /** * Retrieves stats for all servers. * * Returns a map keyed on the servername. The value is another map which * contains stats with stat name as key and value as value. * * @return Stats map */ public Map> stats() { return client.stats(); } /** * Retrieves stats for passed in servers (or all servers). * * Returns a map keyed on the servername. The value is another map which * contains stats with stat name as key and value as value. * * @param servers * string array of servers to retrieve stats from, or all if this * is null * @return Stats map */ public Map> stats(String[] servers) { return client.stats(servers); } /** * Retrieves stats items for all servers. * * Returns a map keyed on the servername. The value is another map which * contains item stats with itemname:number:field as key and value as value. * * @return Stats map */ public Map> statsItems() { return client.statsItems(); } /** * Retrieves stats for passed in servers (or all servers). * * Returns a map keyed on the servername. The value is another map which * contains item stats with itemname:number:field as key and value as value. * * @param servers * string array of servers to retrieve stats from, or all if this * is null * @return Stats map */ public Map> statsItems(String[] servers) { return client.statsItems(servers); } /** * Retrieves stats items for all servers. * * Returns a map keyed on the servername. The value is another map which * contains slabs stats with slabnumber:field as key and value as value. * * @return Stats map */ public Map> statsSlabs() { return client.statsSlabs(); } /** * Retrieves stats for passed in servers (or all servers). * * Returns a map keyed on the servername. The value is another map which * contains slabs stats with slabnumber:field as key and value as value. * * @param servers * string array of servers to retrieve stats from, or all if this * is null * @return Stats map */ public Map> statsSlabs(String[] servers) { return client.statsSlabs(servers); } /** * Retrieves items cachedump for all servers. * * Returns a map keyed on the servername. The value is another map which * contains cachedump stats with the cachekey as key and byte size and unix * timestamp as value. * * @param slabNumber * the item number of the cache dump * @return Stats map */ public Map> statsCacheDump(int slabNumber, int limit) { return client.statsCacheDump(slabNumber, limit); } /** * Retrieves stats for passed in servers (or all servers). * * Returns a map keyed on the servername. The value is another map which * contains cachedump stats with the cachekey as key and byte size and unix * timestamp as value. * * @param servers * string array of servers to retrieve stats from, or all if this * is null * @param slabNumber * the item number of the cache dump * @return Stats map */ public Map> statsCacheDump(String[] servers, int slabNumber, int limit) { return client.statsCacheDump(servers, slabNumber, limit); } public boolean sync(String key, Integer hashCode) { return client.sync(key, hashCode); } public boolean sync(String key) { return client.sync(key); } public boolean syncAll() { return client.syncAll(); } public boolean syncAll(String[] servers) { return client.syncAll(servers); } public boolean append(String key, Object value, Integer hashCode) { return client.append(key, value, hashCode); } public boolean append(String key, Object value) { return client.append(key, value); } public boolean cas(String key, Object value, Integer hashCode, long casUnique) { return client.cas(key, value, hashCode, casUnique); } public boolean cas(String key, Object value, Date expiry, long casUnique) { return client.cas(key, value, expiry, casUnique); } public boolean cas(String key, Object value, Date expiry, Integer hashCode, long casUnique) { return client.cas(key, value, expiry, hashCode, casUnique); } public boolean cas(String key, Object value, long casUnique) { return client.cas(key, value, casUnique); } public boolean prepend(String key, Object value, Integer hashCode) { return client.prepend(key, value, hashCode); } public boolean prepend(String key, Object value) { return client.prepend(key, value); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy