Memcached使用

          mem存取工具类:

import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.lang.management.ManagementFactory;
import java.lang.management.RuntimeMXBean;
import java.text.SimpleDateFormat;
import java.util.Date;

import org.apache.log4j.Logger;

import com.danga.MemCached.MemCachedClient;

public class MemcachedUtils
{
    private static final Logger logger = Logger.getLogger(MemcachedUtils.class);
    private static MemCachedClient cachedClient;
    static
    {
        if (cachedClient == null)
            cachedClient = new MemCachedClient("memcachedPool");
    }

    private MemcachedUtils()
    {
    }

    /**
     * 向缓存添加新的键值对。如果键已经存在,则之前的值将被替换。
     *
     * @param key
     *            键
     * @param value
     *            值
     * @return
     */
    public static boolean set(String key, Object value)
    {
        return setExp(key, value, null);
    }

    /**
     * 向缓存添加新的键值对。如果键已经存在,则之前的值将被替换。
     *
     * @param key
     *            键
     * @param value
     *            值
     * @param expire
     *            过期时间 New Date(1000*10):十秒后过期
     * @return
     */
    public static boolean set(String key, Object value, Date expire)
    {
        return setExp(key, value, expire);
    }

    /**
     * 向缓存添加新的键值对。如果键已经存在,则之前的值将被替换。
     *
     * @param key
     *            键
     * @param value
     *            值
     * @param expire
     *            过期时间 New Date(1000*10):十秒后过期
     * @return
     */
    private static boolean setExp(String key, Object value, Date expire)
    {
        boolean flag = false;
        try
        {
            flag = cachedClient.set(key, value, expire);
        }
        catch (Exception e)
        {
            // 记录Memcached日志
            MemcachedLog.writeLog("Memcached set方法报错,key值:" + key + "\r\n" + exceptionWrite(e));
        }
        return flag;
    }

    /**
     * 仅当缓存中不存在键时,add 命令才会向缓存中添加一个键值对。
     *
     * @param key
     *            键
     * @param value
     *            值
     * @return
     */
    public static boolean add(String key, Object value)
    {
        return addExp(key, value, null);
    }

    /**
     * 仅当缓存中不存在键时,add 命令才会向缓存中添加一个键值对。
     *
     * @param key
     *            键
     * @param value
     *            值
     * @param expire
     *            过期时间 New Date(1000*10):十秒后过期
     * @return
     */
    public static boolean add(String key, Object value, Date expire)
    {
        return addExp(key, value, expire);
    }

    /**
     * 仅当缓存中不存在键时,add 命令才会向缓存中添加一个键值对。
     *
     * @param key
     *            键
     * @param value
     *            值
     * @param expire
     *            过期时间 New Date(1000*10):十秒后过期
     * @return
     */
    private static boolean addExp(String key, Object value, Date expire)
    {
        boolean flag = false;
        try
        {
            flag = cachedClient.add(key, value, expire);
        }
        catch (Exception e)
        {
            // 记录Memcached日志
            MemcachedLog.writeLog("Memcached add方法报错,key值:" + key + "\r\n" + exceptionWrite(e));
        }
        return flag;
    }

    /**
     * 仅当键已经存在时,replace 命令才会替换缓存中的键。
     *
     * @param key
     *            键
     * @param value
     *            值
     * @return
     */
    public static boolean replace(String key, Object value)
    {
        return replaceExp(key, value, null);
    }

    /**
     * 仅当键已经存在时,replace 命令才会替换缓存中的键。
     *
     * @param key
     *            键
     * @param value
     *            值
     * @param expire
     *            过期时间 New Date(1000*10):十秒后过期
     * @return
     */
    public static boolean replace(String key, Object value, Date expire)
    {
        return replaceExp(key, value, expire);
    }

    /**
     * 仅当键已经存在时,replace 命令才会替换缓存中的键。
     *
     * @param key
     *            键
     * @param value
     *            值
     * @param expire
     *            过期时间 New Date(1000*10):十秒后过期
     * @return
     */
    private static boolean replaceExp(String key, Object value, Date expire)
    {
        boolean flag = false;
        try
        {
            flag = cachedClient.replace(key, value, expire);
        }
        catch (Exception e)
        {
            MemcachedLog.writeLog("Memcached replace方法报错,key值:" + key + "\r\n" + exceptionWrite(e));
        }
        return flag;
    }

    /**
     * get 命令用于检索与之前添加的键值对相关的值。
     *
     * @param key
     *            键
     * @return
     */
    public static Object get(String key)
    {
        Object obj = null;
        try
        {
            obj = cachedClient.get(key);
        }
        catch (Exception e)
        {
            MemcachedLog.writeLog("Memcached get方法报错,key值:" + key + "\r\n" + exceptionWrite(e));
        }
        return obj;
    }

    /**
     * 删除 memcached 中的任何现有值。
     *
     * @param key
     *            键
     * @return
     */
    public static boolean delete(String key)
    {
        return deleteExp(key, null);
    }

    /**
     * 删除 memcached 中的任何现有值。
     *
     * @param key
     *            键
     * @param expire
     *            过期时间 New Date(1000*10):十秒后过期
     * @return
     */
    public static boolean delete(String key, Date expire)
    {
        return deleteExp(key, expire);
    }

    /**
     * 删除 memcached 中的任何现有值。
     *
     * @param key
     *            键
     * @param expire
     *            过期时间 New Date(1000*10):十秒后过期
     * @return
     */
    private static boolean deleteExp(String key, Date expire)
    {
        boolean flag = false;
        try
        {
            flag = cachedClient.delete(key, expire);
        }
        catch (Exception e)
        {
            MemcachedLog.writeLog("Memcached delete方法报错,key值:" + key + "\r\n" + exceptionWrite(e));
        }
        return flag;
    }

    /**
     * 清理缓存中的所有键/值对
     *
     * @return
     */
    public static boolean flashAll()
    {
        boolean flag = false;
        try
        {
            flag = cachedClient.flushAll();
        }
        catch (Exception e)
        {
            MemcachedLog.writeLog("Memcached flashAll方法报错\r\n" + exceptionWrite(e));
        }
        return flag;
    }

    /**
     * 返回异常栈信息,String类型
     *
     * @param e
     * @return
     */
    private static String exceptionWrite(Exception e)
    {
        StringWriter sw = new StringWriter();
        PrintWriter pw = new PrintWriter(sw);
        e.printStackTrace(pw);
        pw.flush();
        return sw.toString();
    }

    /**
     *
     * @ClassName: MemcachedLog
     * @Description: Memcached日志记录
     *
     */
    private static class MemcachedLog
    {
        private final static String MEMCACHED_LOG = "D:\\memcached.log";
        private final static String LINUX_MEMCACHED_LOG = "/usr/local/logs/memcached.log";
        private static FileWriter fileWriter;
        private static BufferedWriter logWrite;
        // 获取PID,可以找到对应的JVM进程
        private final static RuntimeMXBean runtime = ManagementFactory.getRuntimeMXBean();
        private final static String PID = runtime.getName();

        /**
         * 初始化写入流
         */
        static
        {
            try
            {
                String osName = System.getProperty("os.name");
                if (osName.indexOf("Windows") == -1)
                {
                    fileWriter = new FileWriter(MEMCACHED_LOG, true);
                }
                else
                {
                    fileWriter = new FileWriter(LINUX_MEMCACHED_LOG, true);
                }
                logWrite = new BufferedWriter(fileWriter);
            }
            catch (IOException e)
            {
                logger.error("memcached 日志初始化失败", e);
                closeLogStream();
            }
        }

        /**
         * 写入日志信息
         *
         * @param content
         *            日志内容
         */
        public static void writeLog(String content)
        {
            try
            {
                logWrite.write("[" + PID + "] " + "- ["
                        + new SimpleDateFormat("yyyy年-MM月-dd日 hh时:mm分:ss秒").format(new Date().getTime()) + "]\r\n"
                        + content);
                logWrite.newLine();
                logWrite.flush();
            }
            catch (IOException e)
            {
                logger.error("memcached 写入日志信息失败", e);
            }
        }

        /**
         * 关闭流
         */
        private static void closeLogStream()
        {
            try
            {
                fileWriter.close();
                logWrite.close();
            }
            catch (IOException e)
            {
                logger.error("memcached 日志对象关闭失败", e);
            }
        }
    }
}



简单使用:

    public static void main(String[] args) {
try {
// 本地连接 Memcached 服务
MemcachedClient mcc = new MemcachedClient(new InetSocketAddress("127.0.0.1", 11211));
System.out.println("Connection to server sucessful.");
System.out.println(mcc.get("ada"));
mcc.add("ada", 100000, "aaaaaaa");
System.out.println(mcc.get("ada"));
// 关闭连接
mcc.shutdown();

} catch (Exception ex) {
System.out.println(ex.getMessage());
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值