• Memcached学习笔记之六:java 连接 Memcached


    基于 java_memcached-release_2.6.6

    1.工具类(含日志类) : MemcachedUtils.java

    package com.harmonywisdom.ajproduct.utils;
    
    import com.danga.MemCached.MemCachedClient;
    import com.danga.MemCached.SockIOPool;
    import com.schooner.MemCached.MemcachedItem;
    
    import java.io.*;
    import java.lang.management.ManagementFactory;
    import java.text.SimpleDateFormat;
    import java.util.Date;
    
    /**
     * Memcached 工具类
     * Created by zhengyou on 2017/5/9.
     */
    public final class MemcachedUtils {
        private static MemCachedClient memCachedClient;
    
        static {
            /************** 配置 Memcached  ****************/
            System.out.println("/************** 配置 Memcached  ****************/");
    
    
            // 获取连接池的实例对象
            SockIOPool sockIOPool = SockIOPool.getInstance();
            // 服务器列表和其权重
            String[] servers = {"127.0.0.1:11211"};
            Integer[] weights = {3};
    
            sockIOPool.setServers(servers);//设置memcached服务器地址
            sockIOPool.setWeights(weights); //设置每个MemCached服务器权重
    
            sockIOPool.setAliveCheck(true);  //设置是否检查memcached服务器是否失效
            sockIOPool.setFailover(true);//当一个memcached服务器失效的时候是否去连接另一个memcached服务器.
    
            // 设置初始连接数、最小和最大连接数以及最大处理时间
            sockIOPool.setInitConn(10); //初始化时对每个服务器建立的连接数目
            sockIOPool.setMinConn(10);  //每个服务器建立最小的连接数
            sockIOPool.setMaxConn(100);  //每个服务器建立最大的连接数
            sockIOPool.setMaxIdle(1000 * 30 * 30);  // 设置最大处理时间
    
    
            // 设置主线程的睡眠时间
            sockIOPool.setMaintSleep(30);  //自查线程周期进行工作,其每次休眠时间
    
            // 设置TCP的参数,连接超时等
            sockIOPool.setNagle(false);   //Socket的参数,如果是true在写数据时不缓冲,立即发送出去。Tcp的规则是在发送一个包之前,包的发送方会等待远程接收方确认已收到上一次发送过来的包;这个方法就可以关闭套接字的缓存——包准备立即发出。
            sockIOPool.setSocketTO(3000);  //Socket阻塞读取数据的超时时间
            sockIOPool.setSocketConnectTO(0);   //连接建立时对超时的控制
            // 初始化连接池
            System.out.println(" 初始化连接池...");
            sockIOPool.initialize();
    
            if (memCachedClient == null) {
                memCachedClient = new MemCachedClient();
    //            memCachedClient.setPrimitiveAsString(true);        //是否将基本类型转换为String方法
            }
        }
    
        /**
         * 保护型构造方法,不允许实例化!
         */
        private MemcachedUtils() {
        }
    
        /**
         * 添加指定对象到缓存中。
         * 注意:若key已经存在,旧value会被新value替换。
         *
         * @param key   键
         * @param value 值
         * @return boolean
         */
        public static boolean set(String key, Object value) {
            try {
                return memCachedClient.set(key, value);
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached set方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return false;
            }
        }
    
        /**
         * 添加指定对象到缓存中,并设置过期时间(如 new Date(1000*10) 表示10秒后过期)。
         * 注意:若key已经存在,旧value会被新value替换。
         *
         * @param key    键
         * @param value  值
         * @param expire 过期时间
         * @return boolean
         */
        public static boolean set(String key, Object value, Date expire) {
            try {
                return memCachedClient.set(key, value, expire);
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached set方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return false;
            }
        }
    
        /**
         * 根据key获取value值
         *
         * @param key 键
         * @return Object || null
         */
        public static Object get(String key) {
            try {
                return memCachedClient.get(key);
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached get方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return null;
            }
        }
    
    
        /**
         * 向缓存中添加键值对。
         * 注意: 当key不存在时,才能添加成功
         *
         * @param key   键
         * @param value 值
         * @return boolean
         */
        public static boolean add(String key, Object value) {
            try {
                if (get(key) != null) {
                    MemcachedLogUtils.writeLog("Memcached add方法报错,key值:" + key + "
    " + exceptionWrite(new Exception("Memcached内存缓存中已经存在该键值对")));
                    return false;
                }
                return memCachedClient.add(key, value);
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached add方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return false;
            }
        }
    
        /**
         * 向缓存添加键值对并为该键值对设定过期时间(比如: new Date(1000*10),则表示十秒之后从Memcached内存缓存中删除)。
         * 注意:仅当缓存中不存在键时,才会添加成功。
         *
         * @param key    键
         * @param value  值
         * @param expire 过期时间
         * @return boolean
         */
        public static boolean add(String key, Object value, Date expire) {
            try {
                if (get(key) != null) {
                    MemcachedLogUtils.writeLog("Memcached add方法报错,key值:" + key + "
    " + exceptionWrite(new Exception("Memcached内存缓存中已经存在该键值对")));
                    return false;
                } else {
                    return memCachedClient.add(key, value, expire);
                }
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached add方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return false;
            }
        }
    
        /**
         * 用新值替换已存在key的旧值
         * 注意:只有该键存在时,才会替换键相应的值。
         *
         * @param key      键
         * @param newValue 新的值
         * @return boolean
         */
        public static boolean replace(String key, Object newValue) {
            try {
                return memCachedClient.replace(key, newValue);
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached replace方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return false;
            }
        }
    
        /**
         * 用新值替换已存在key的旧值,并设置过期时间(比如: new Date(1000*10),则表示十秒之后从Memcached内存缓存中删除)。
         * 注意:只有该键存在时,才会替换键相应的值。
         *
         * @param key      键
         * @param newValue 新的值
         * @param expire   过期时间
         * @return boolean
         */
        public static boolean replace(String key, Object newValue, Date expire) {
            try {
                return memCachedClient.replace(key, newValue, expire);
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached replace方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return false;
            }
        }
    
        /**
         * 根据键删除memcached中的键/值对
         *
         * @param key 键
         * @return boolean
         */
        public static boolean delete(String key) {
            try {
                return memCachedClient.delete(key);
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached delete方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return false;
            }
        }
    
        /**
         * 向已经存在的key的value后面追加数据
         *
         * @param key         已经存在的键
         * @param appendValue 追加的数据
         * @return boolean
         */
        public static boolean append(String key, Object appendValue) {
            try {
                if (get(key) == null) {
                    MemcachedLogUtils.writeLog("Memcached append方法报错,key值:" + key + "
    " + exceptionWrite(new Exception("Memcached内存缓存中不存在该键值对")));
                    return false;
                }
                return memCachedClient.append(key, appendValue);
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached append方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return false;
            }
        }
    
        /**
         * 向已经存在的key的value 前面 追加数据
         *
         * @param key          键
         * @param prependValue 追加的值
         * @return boolean
         */
        public static boolean prepend(String key, Object prependValue) {
            try {
                if (get(key) == null) {
                    MemcachedLogUtils.writeLog("Memcached prepend方法报错,key值:" + key + "
    " + exceptionWrite(new Exception("Memcached内存缓存中不存在该键值对")));
                    return false;
                }
                return memCachedClient.prepend(key, prependValue);
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached prepend方法报错,key值:" + key + "
    " + exceptionWrite(e));
                return false;
            }
        }
    
    
        /**
         * 清理缓存中的所有键/值对
         */
        public static boolean flashAll() {
            try {
                return memCachedClient.flushAll();
            } catch (Exception e) {
                MemcachedLogUtils.writeLog("Memcached flashAll方法报错
    " + exceptionWrite(e));
                return false;
            }
        }
    
        /**
         * 返回String类型的异常栈信息
         */
        private static String exceptionWrite(Exception exception) {
            StringWriter stringWriter = new StringWriter();
            PrintWriter printWriter = new PrintWriter(stringWriter);
            exception.printStackTrace(printWriter);
            printWriter.flush();
            return stringWriter.toString();
        }
    
    
        /**
         * Memcached日志记录工具
         * Created by zhengyou on 2017/5/9.
         */
        private static class MemcachedLogUtils {
    
            private static FileWriter fileWriter;
            private static BufferedWriter logWrite;
            private final static String PID = ManagementFactory.getRuntimeMXBean().getName();// 通过找到对应的JVM进程获取PID
    
            //初始化Memcached日志写入流
            static {
                try {
                    String osName = System.getProperty("os.name");
                    if (osName.contains("Windows")) {
                        fileWriter = new FileWriter("D:\memcached.log", true);
                    } else {
                        fileWriter = new FileWriter("/usr/local/logs/memcached.log", true);
                    }
                    logWrite = new BufferedWriter(fileWriter);
                } catch (IOException iOException) {
                    iOException.printStackTrace();
                    try {
                        if (fileWriter != null) {
                            fileWriter.close();
                        }
                        if (logWrite != null) {
                            logWrite.close();
                        }
                    } catch (Exception exception) {
                        exception.printStackTrace();
                    }
                }
            }
    
            /**
             * 写入日志信息
             *
             * @author GaoHuanjie
             */
            private static void writeLog(String logContent) {
                try {
                    logWrite.write("[" + PID + "] " + "- [" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()) + "]
    " + logContent);
                    logWrite.newLine();
                    logWrite.flush();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
    View Code

    2. 测试类:MemcachedUtilsTest.java

    package com.harmonywisdom.ajproduct.test;
    
    import com.harmonywisdom.ajproduct.utils.MemcachedUtils;
    
    /**
     * MemcachedUtils 测试类
     * Created by zynmx on 2017/5/10.
     */
    public class MemcachedUtilsTest {
    
    
        public static void main(String[] args) {
            long startDate = System.currentTimeMillis();
            System.out.println(startDate);
            for (int i = 0; i < 10000 * 10; i++) {
                MemcachedUtils.add("test" + i, "中国");
            }
            long endDate = System.currentTimeMillis();
            System.out.println(endDate);
            long nowDate = (endDate - startDate) / 1000;
            System.out.println(nowDate);
            System.out.print(" get value : " + MemcachedUtils.get("test0"));
        }
    
    
    }
    View Code
  • 相关阅读:
    The test form is only available for requests from the local machine
    64位Win7下,先安装Visual Studio,后安装IIS的设置步骤
    [转] 如何在 64 位的 Windows 7 中安裝 PLSQL DEVELOPER 8 和 Oracle 11g x64 Client
    excel对csv的转义
    js中没有引用的匿名函数调用方法
    缓存实现条件
    js对象成员的删除特性 (delete)
    js语法作用域之间的相关性
    【转】UBOOT之四:uboot.lds分析
    linux C 中的volatile使用
  • 原文地址:https://www.cnblogs.com/VweiweiyixiaoV/p/6837154.html
Copyright © 2020-2023  润新知