Java 中常用緩存Cache機制的實現


所謂緩存,就是將程序或系統經常要調用的對象存在內存中,一遍其使用時可以快速調用,不必再去創建新的重復的實例。這樣做可以減少系統開銷,提高系統效率。

所謂緩存,就是將程序或系統經常要調用的對象存在內存中,一遍其使用時可以快速調用,不必再去創建新的重復的實例。這樣做可以減少系統開銷,提高系統效率。

緩存主要可分為二大類: 

一、通過文件緩存,顧名思義文件緩存是指把數據存儲在磁盤上,不管你是以XML格式,序列化文件DAT格式還是其它文件格式;  

二、內存緩存,也就是實現一個類中靜態Map,對這個Map進行常規的增刪查. 

代碼如下:

package lhm.hcy.guge.frameset.cache; 
 
import java.util.*; 
 
 //Description: 管理緩存 
 
 //可擴展的功能:當chche到內存溢出時必須清除掉最早期的一些緩存對象,這就要求對每個緩存對象保存創建時間 
 
public class CacheManager { 
    private static HashMap cacheMap = new HashMap(); 
 
    //單實例構造方法 
    private CacheManager() { 
        super(); 
    } 
    //獲取布爾值的緩存 
    public static boolean getSimpleFlag(String key){ 
        try{ 
            return (Boolean) cacheMap.get(key); 
        }catch(NullPointerException e){ 
            return false; 
        } 
    } 
    public static long getServerStartdt(String key){ 
        try { 
            return (Long)cacheMap.get(key); 
        } catch (Exception ex) { 
            return 0; 
        } 
    } 
    //設置布爾值的緩存 
    public synchronized static boolean setSimpleFlag(String key,boolean flag){ 
        if (flag && getSimpleFlag(key)) {//假如為真不允許被覆蓋 
            return false; 
        }else{ 
            cacheMap.put(key, flag); 
            return true; 
        } 
    } 
    public synchronized static boolean setSimpleFlag(String key,long serverbegrundt){ 
        if (cacheMap.get(key) == null) { 
            cacheMap.put(key,serverbegrundt); 
            return true; 
        }else{ 
            return false; 
        } 
    } 
 
 
    //得到緩存。同步靜態方法 
    private synchronized static Cache getCache(String key) { 
        return (Cache) cacheMap.get(key); 
    } 
 
    //判斷是否存在一個緩存 
    private synchronized static boolean hasCache(String key) { 
        return cacheMap.containsKey(key); 
    } 
 
    //清除所有緩存 
    public synchronized static void clearAll() { 
        cacheMap.clear(); 
    } 
 
    //清除某一類特定緩存,通過遍歷HASHMAP下的所有對象,來判斷它的KEY與傳入的TYPE是否匹配 
    public synchronized static void clearAll(String type) { 
        Iterator i = cacheMap.entrySet().iterator(); 
        String key; 
        ArrayList arr = new ArrayList(); 
        try { 
            while (i.hasNext()) { 
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next(); 
                key = (String) entry.getKey(); 
                if (key.startsWith(type)) { //如果匹配則刪除掉 
                    arr.add(key); 
                } 
            } 
            for (int k = 0; k < arr.size(); k++) { 
                clearOnly(arr.get(k)); 
            } 
        } catch (Exception ex) { 
            ex.printStackTrace(); 
        } 
    } 
 
    //清除指定的緩存 
    public synchronized static void clearOnly(String key) { 
        cacheMap.remove(key); 
    } 
 
    //載入緩存 
    public synchronized static void putCache(String key, Cache obj) { 
        cacheMap.put(key, obj); 
    } 
 
    //獲取緩存信息 
    public static Cache getCacheInfo(String key) { 
 
        if (hasCache(key)) { 
            Cache cache = getCache(key); 
            if (cacheExpired(cache)) { //調用判斷是否終止方法 
                cache.setExpired(true); 
            } 
            return cache; 
        }else 
            return null; 
    } 
 
    //載入緩存信息 
    public static void putCacheInfo(String key, Cache obj, long dt,boolean expired) { 
        Cache cache = new Cache(); 
        cache.setKey(key); 
        cache.setTimeOut(dt + System.currentTimeMillis()); //設置多久后更新緩存 
        cache.setValue(obj); 
        cache.setExpired(expired); //緩存默認載入時,終止狀態為FALSE 
        cacheMap.put(key, cache); 
    } 
    //重寫載入緩存信息方法 
    public static void putCacheInfo(String key,Cache obj,long dt){ 
        Cache cache = new Cache(); 
        cache.setKey(key); 
        cache.setTimeOut(dt+System.currentTimeMillis()); 
        cache.setValue(obj); 
        cache.setExpired(false); 
        cacheMap.put(key,cache); 
    } 
 
    //判斷緩存是否終止 
    public static boolean cacheExpired(Cache cache) { 
        if (null == cache) { //傳入的緩存不存在 
            return false; 
        } 
        long nowDt = System.currentTimeMillis(); //系統當前的毫秒數 
        long cacheDt = cache.getTimeOut(); //緩存內的過期毫秒數 
        if (cacheDt <= 0||cacheDt>nowDt) { //過期時間小於等於零時,或者過期時間大於當前時間時,則為FALSE 
            return false; 
        } else { //大於過期時間 即過期 
            return true; 
        } 
    } 
 
    //獲取緩存中的大小 
    public static int getCacheSize() { 
        return cacheMap.size(); 
    } 
 
    //獲取指定的類型的大小 
    public static int getCacheSize(String type) { 
        int k = 0; 
        Iterator i = cacheMap.entrySet().iterator(); 
        String key; 
        try { 
            while (i.hasNext()) { 
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next(); 
                key = (String) entry.getKey(); 
                if (key.indexOf(type) != -1) { //如果匹配則刪除掉 
                    k++; 
                } 
            } 
        } catch (Exception ex) { 
            ex.printStackTrace(); 
        } 
 
        return k; 
    } 
 
    //獲取緩存對象中的所有鍵值名稱 
    public static ArrayList getCacheAllkey() { 
        ArrayList a = new ArrayList(); 
        try { 
            Iterator i = cacheMap.entrySet().iterator(); 
            while (i.hasNext()) { 
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next(); 
                a.add((String) entry.getKey()); 
            } 
        } catch (Exception ex) {} finally { 
            return a; 
        } 
    } 
 
    //獲取緩存對象中指定類型 的鍵值名稱 
    public static ArrayList getCacheListkey(String type) { 
        ArrayList a = new ArrayList(); 
        String key; 
        try { 
            Iterator i = cacheMap.entrySet().iterator(); 
            while (i.hasNext()) { 
                java.util.Map.Entry entry = (java.util.Map.Entry) i.next(); 
                key = (String) entry.getKey(); 
                if (key.indexOf(type) != -1) { 
                    a.add(key); 
                } 
            } 
        } catch (Exception ex) {} finally { 
            return a; 
        } 
    } 
 
} 
 
 
package lhm.hcy.guge.frameset.cache; 
 
public class Cache { 
        private String key;//緩存ID 
        private Object value;//緩存數據 
        private long timeOut;//更新時間 
        private boolean expired; //是否終止 
        public Cache() { 
                super(); 
        } 
 
        public Cache(String key, Object value, long timeOut, boolean expired) { 
                this.key = key; 
                this.value = value; 
                this.timeOut = timeOut; 
                this.expired = expired; 
        } 
 
        public String getKey() { 
                return key; 
        } 
 
        public long getTimeOut() { 
                return timeOut; 
        } 
 
        public Object getValue() { 
                return value; 
        } 
 
        public void setKey(String string) { 
                key = string; 
        } 
 
        public void setTimeOut(long l) { 
                timeOut = l; 
        } 
 
        public void setValue(Object object) { 
                value = object; 
        } 
 
        public boolean isExpired() { 
                return expired; 
        } 
 
        public void setExpired(boolean b) { 
                expired = b; 
        } 
} 
 
//測試類, 
class Test { 
    public static void main(String[] args) { 
        System.out.println(CacheManager.getSimpleFlag("alksd")); 
//        CacheManager.putCache("abc", new Cache()); 
//        CacheManager.putCache("def", new Cache()); 
//        CacheManager.putCache("ccc", new Cache()); 
//        CacheManager.clearOnly(""); 
//        Cache c = new Cache(); 
//        for (int i = 0; i < 10; i++) { 
//            CacheManager.putCache("" + i, c); 
//        } 
//        CacheManager.putCache("aaaaaaaa", c); 
//        CacheManager.putCache("abchcy;alskd", c); 
//        CacheManager.putCache("cccccccc", c); 
//        CacheManager.putCache("abcoqiwhcy", c); 
//        System.out.println("刪除前的大小:"+CacheManager.getCacheSize()); 
//        CacheManager.getCacheAllkey(); 
//        CacheManager.clearAll("aaaa"); 
//        System.out.println("刪除后的大小:"+CacheManager.getCacheSize()); 
//        CacheManager.getCacheAllkey(); 
 
 
    } 
} 

spring中的redis service實現

package com.eshore.ismp.cache.redis;

import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.dao.DataAccessException;
import org.springframework.data.redis.connection.RedisConnection;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Service;

@Service
public class RedisService {

	private static String redisCode = "utf-8";
	
	@Autowired
	private RedisTemplate<String, String> redisTemplate;

	/**
	 * 從指定的列表右邊出隊,添加到目的列表中
	 * 
	 * @param srckey
	 *            源列表
	 * @param dstkey
	 *             目的列表
	 * @return
	 */
	public String rpoppush(final String srckey, final String dstkey) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				try {
					return new String (connection.rPopLPush(srckey.getBytes(), dstkey.getBytes()), redisCode);
				} catch (UnsupportedEncodingException e) {
					e.printStackTrace();
				}
				return "";
			}
		});
	}
	/**
	 * 獲取指定列表的范圍數據
	 * 
	 * @param key
	 *             列表名
	 * @param start
	 *             開始位置
	 * @param end
	 *             結束位置
	 * @return
	 */
	public List<String> lrange(final String key, final int start, final int end) {
		return redisTemplate.execute(new RedisCallback<List<String>>() {
			List<String> result = new ArrayList<String>();
			public List<String> doInRedis(RedisConnection connection)
					throws DataAccessException {
				List<byte[]> bytelist= connection.lRange(key.getBytes(), start, end);
				for (byte[] b : bytelist) {
					try {
						result.add(new String(b, redisCode));
					} catch (UnsupportedEncodingException e) {
						e.printStackTrace();
					}
				}
				return result;
			}
		});
	}
	/**
	 * 從隊列的左邊取出一條數據
	 * 
	 * @param key
	 *             列表名
	 * @return
	 */
	public String lpop(final String key) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				byte[] result = connection.lPop(key.getBytes());
				if (result != null) {
					try {
						return new String (result , redisCode);
					} catch (UnsupportedEncodingException e) {
						e.printStackTrace();
					}
				}
				return "";
			}
		});
	}
	
	/**
	 * 從隊列的左邊取出一條數據
	 * 
	 * @param key
	 *             列表名
	 * @return
	 */
	public List<?> lpop(final String key,final int size) {
		List<Object> list =  redisTemplate.executePipelined(new RedisCallback<List<Object>>() {
			public List<Object> doInRedis(RedisConnection connection)
					throws DataAccessException {
				byte[] keyBytes = key.getBytes();
				for(int i =0 ; i< size; i++){
					connection.lPop(keyBytes);
				}
				return null;
			}
		});
		list.removeAll(Collections.singleton(null));
		return list;
	}
	
	/**
	 * 從列表右邊添加數據
	 * 
	 * @param key
	 *            列表名
	 * @param values
	 *            數據
	 * @return
	 */
	public long rpush(final String key, final String... values) {
        return redisTemplate.execute(new RedisCallback<Long>() {
            public Long doInRedis(RedisConnection connection)
                    throws DataAccessException {
                long result = 0;
                for (String v : values) {
                	result = connection.rPush(key.getBytes(), v.getBytes());
                }
                return result;
            }
        });
	}
	
	/**
	 * 從列表右邊添加數據
	 * 
	 * @param key
	 *            列表名
	 * @param values
	 *            數據
	 * @return
	 */
	public long rpush(final String key, final Collection<String> values) {
		return redisTemplate.opsForList().rightPushAll(key, values);
	}
	
	public int hmset(final String key, final Map<String,String> values) {
		try{
		 redisTemplate.opsForHash().putAll(key, values);
		}catch(Exception e){
			e.printStackTrace();
			return -1;
		}
		return 0 ;
	}
	public String hget(final String key, final String field){
		Object obj =redisTemplate.opsForHash().get(key, field);
		return String.valueOf(obj);
	}
	
	public List<?> hkeys(final String key){
		return redisTemplate.execute(new RedisCallback<List<Object>>(){
			List<Object> list = new ArrayList<Object>();
			public List<Object> doInRedis(RedisConnection connection)
					throws DataAccessException {
				Set<byte[]> sets=connection.hKeys(key.getBytes());
				if(!sets.isEmpty()){
					for(byte[] b : sets){
						list.add(redisTemplate.getValueSerializer().deserialize(b).toString());
					}
					return list;
				}
				return null;
			}
		});
	}
	
	/**
	 * 刪除hash表中field
	 */
	public void hdel(final String key,final String field){
		redisTemplate.opsForHash().delete(key, field);
	}
	/**
	 * 從列表右邊添加數據,並且設置列表的存活時間
	 * 
	 * @param key
	 *            列表名
	 * @param liveTime
	 *            存活時間(單位 秒)
	 * @param values
	 *            數據
	 * @return
	 */
	public long rpush(final String key, final int liveTime, final String... values) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				long result = 0; 
				for (String v : values) {
					connection.rPush(key.getBytes(), v.getBytes());
				}
				if (liveTime > 0) {
					connection.expire(key.getBytes(), liveTime);
				}	
				return result;
			}
		});
	}
	/**
	 * 從隊列的右邊取出一條數據
	 * 
	 * @param key
	 *            列表名
	 * @return
	 */
	public String rpop(final String key) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				byte[] result = connection.rPop(key.getBytes());
				if(result != null ){
					try {
						return new String (result, redisCode);
					} catch (UnsupportedEncodingException e) {
						e.printStackTrace();
					}
				}
				return "";
			}
		});
	}
	/**
	 * 把一個值添加到對應列表中
	 * 
	 * @param key
	 *            列表名
	 * @param index
	 *             添加的位置
	 * @param value
	 *             數據
	 * @return
	 */
	public String lset(final String key, final long index, final String value) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				connection.lSet(key.getBytes(), index, value.getBytes());
				return "success";
			}
		});
	}
	/**
	 * 把所有數據添加到一個列表中
	 * 
	 * @param key
	 *            列表名
	 * @param values
	 *             數據
	 * @return
	 */
	public long lpush(String key, String... values) {
		return this.lpush(key, 0, values);
	}
	/**
	 * 把所有數據添加到一個列表中,並且設置列表的存活時間
	 * 
	 * @param key
	 *            列表名
	 * @param values
	 *            數據
	 * @param liveTime
	 *            存活時間--單位(秒)
	 * @return
	 */
	public long lpush(final String key,final  int liveTime, final String... values) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				long result = 0;
				for (String v : values){
					result = connection.lPush(key.getBytes(), v.getBytes());
				}
				if (liveTime > 0) {
					connection.expire(key.getBytes(), liveTime);
				}
				return result;
			}
		});
	}
	/**
	 * 返回列表的長度
	 * 
	 * @param key
	 * @return
	 */
	public long llen(final String key) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.lLen(key.getBytes());
			}
		});
	}
	/**
	 * 刪除列表中對應值的元素
	 * 
	 * @param key
	 *            列表名
	 * @param count
	 *            刪除多少個相同的元素
	 * @param value
	 *            數據
	 * @return
	 */
	public long lrem(final String key, final long count, final String value) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.lRem(key.getBytes(), count, value.getBytes());
			}
		});
	}
	/**
	 * 通過keys批量刪除
	 * 
	 * @param key
	 */
	public long del(final String... keys) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				long result = 0;
				for (String k : keys) {
					result = connection.del(k.getBytes());
				}
				return result;
			}
		});
	}
	
	/**
	 * 
	 * //DESC 刪除單個key
	 * @time: 2016年5月27日 上午9:00:36
	 * @param key
	 * @return
	 * @throws
	 */
	public long del(final String key){
		return redisTemplate.execute(new RedisCallback<Long>(){
			@Override
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.del(key.getBytes());
			}
			
		});
	}
	
	
	/**
	 * 添加key value 並且設置存活時間(byte)
	 * 
	 * @param key
	 * @param value
	 * @param liveTime
	 */
	public void set(final byte[] key, final byte[] value, final long liveTime) {
		redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				connection.set(key, value);
                if (liveTime > 0) {
                    connection.expire(key, liveTime);
                }
				return 1L;
			}
		});
		
	}
	/**
	 * 添加key value 並且設置存活時間
	 * 
	 * @param key
	 * @param value
	 * @param liveTime
	 *            單位秒
	 */
	public void set(String key, String value, long liveTime) {
		this.set(key.getBytes(), value.getBytes(), liveTime);
		
	}
	/**
	 * 添加key value
	 * 
	 * @param key
	 * @param value
	 */
	public void set(String key, String value) {
		this.set(key, value, 0L);
	}
	
	/**
	 * 添加key value
	 * 
	 * @param key
	 * @param value
	 */
	public void setMulti(final Map<String,String> map) {
		setMulti(map,0L);
	}
	
	/**
	 * 添加key value
	 * 
	 * @param key
	 * @param value
	 */
	public void setMulti(final Map<String,String> map,final long liveTime) {
		 redisTemplate.executePipelined(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				Set<Map.Entry<String, String >> set = map.entrySet();
				for (Entry<String, String> entry : set) {
					connection.set(entry.getKey().getBytes(), entry.getValue().getBytes());
					if (liveTime > 0) {
		                connection.expire(entry.getKey().getBytes(), liveTime);
		            }
				}
				return null;
			}
		});
	}
	/**
	 * 添加key value (字節)(序列化)
	 * 
	 * @param key
	 * @param value
	 */
	public void set(byte[] key, byte[] value) {
		this.set(key, value, 0L);
		
	}
	/**
	 * 獲取redis value (String)
	 * 
	 * @param key
	 * @return
	 */
	public String get(final String key) {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
			byte[] result = connection.get(key.getBytes());
			if (result != null) {
				try {
					return new String (result ,redisCode);
				} catch (UnsupportedEncodingException e) {
					e.printStackTrace();
				}	
			}
			return "";
			}
		});
	}
	/**
	 * 如果key不存在添加key value 並且設置存活時間(byte),當key已經存在時,就不做任何操作
	 * 
	 * @param key
	 * @param value
	 * @param liveTime
	 */
	public long setnx(final byte[] key, final byte[] value, final long liveTime) {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				long result = 0l;
				boolean isSuccess = connection.setNX(key, value);
                if (isSuccess) {
                	if (liveTime > 0) {
                        connection.expire(key, liveTime);
                    }
					result = 1l;
				}
				return result;
			}
		});
	}
	/**
	 * 如果key不存在添加key value 並且設置存活時間,當key已經存在時,就不做任何操作
	 * 
	 * @param key
	 * @param value
	 * @param liveTime
	 *            單位秒
	 */
	public long setnx(String key, String value, long liveTime) {
		return this.setnx(key.getBytes(), value.getBytes(), liveTime);
		
	}
	/**
	 * 如果key不存在添加key value,當key已經存在時,就不做任何操作
	 * 
	 * @param key
	 * @param value
	 */
	public long setnx(String key, String value) {
		return this.setnx(key, value, 0L);
	}
	/**
	 * 如果key不存在添加key value (字節)(序列化),當key已經存在時,就不做任何操作
	 * 
	 * @param key
	 * @param value
	 */
	public long setnx(byte[] key, byte[] value) {
		return this.setnx(key, value, 0L);
		
	}
	/**
	 * 通過正則匹配keys
	 * 
	 * @param pattern
	 * @return
	 */
	public Set<String> keys(final String pattern) {
		return redisTemplate.execute(new RedisCallback<Set<String>>() {
			public Set<String> doInRedis(RedisConnection connection)
					throws DataAccessException {
			Set<String> result = new HashSet<String>();
			Set<byte[]>	data = connection.keys(pattern.getBytes());
			for(byte[] d : data){
				try {
					result.add(new String(d,redisCode));
				} catch (UnsupportedEncodingException e) {
					e.printStackTrace();
				}
			}
			return result;
			}
		});
	}
	/**
	 * 檢查key是否已經存在
	 * 
	 * @param key
	 * @return
	 */
	public boolean exists(final String key) {
		return redisTemplate.execute(new RedisCallback<Boolean>() {
			public Boolean doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.exists(key.getBytes());
			}
			
		});
	}
	/**
	 * 清空redis 所有數據
	 * 
	 * @return
	 */
	public String flushDB() {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				connection.flushDb();
				return "success";
			}
		});
	}
	/**
	 * 查看redis里有多少數據
	 */
	public long dbSize() {
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.dbSize();
			}
		});
	}
	/**
	 * 檢查是否連接成功
	 * 
	 * @return
	 */
	public String ping() {
		return redisTemplate.execute(new RedisCallback<String>() {
			public String doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.ping();
			}
		});
	}
	/**
	 * 設置key的生命周期
	 * 
	 * @param key
	 * @param seconds
	 *            單位(秒)
	 * @return
	 */
	public boolean expire(final String key, final long seconds) {
		return redisTemplate.execute(new RedisCallback<Boolean>() {
			public Boolean doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.expire(key.getBytes(), seconds);
			}
		});
	}
	/**
	 * 自增長
	 * 
	 * @param key
	 * @param length 增長步長
	 * @return
	 */
	public long incr (final String key){
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.incr(key.getBytes());
			}
			
		});
	}
	/**
	 * 自增長
	 * 
	 * @param key
	 * @param length 增長步長
	 * @return
	 */
	public long incrBy (final String key, final long len){
		return redisTemplate.execute(new RedisCallback<Long>() {
			public Long doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.incrBy(key.getBytes(), len);
			}
		});
		
	}
	/**
	 * 自增長
	 * 
	 * @param key
	 * @param length 增長步長
	 * @return
	 */
	public double incrBy (final String key, final double len){
		return redisTemplate.execute(new RedisCallback<Double>() {
			public Double doInRedis(RedisConnection connection)
					throws DataAccessException {
				return connection.incrBy(key.getBytes(), len);
			}
		});
	}
	
    public long eval(final String luaCommand) {
        return redisTemplate.execute(new RedisCallback<Long>() {
            public Long doInRedis(RedisConnection connection) throws DataAccessException {
                return connection.eval(luaCommand.getBytes(), null,0);
            }
        });
    }

}

  

緩存應用:

package com.eshore.ismp.cache.processor;

import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.StringUtils;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.eshore.ismp.cache.redis.RedisService;
import com.eshore.ismp.common.entity.ResultInfo;

/**
 * 
 * //DESC: 管理門戶緩存接口
 * @author zzx
 * @date 2016年5月20日 上午11:50:25
 */
@Service
public class AdminWebProcessor {
	private static final Logger logger = Logger.getLogger(AdminWebProcessor.class);
	private static final String ADMINWEB_USER = "ADMINWEB_USER_";
	private static final Long LIVETIME = 60*30L;
	@Autowired
	RedisService redisService;
	
	public String put(JSONObject param){
		Long userId = param.getLong("user_id");
		String userInfo = param.getString("user_info");
		ResultInfo  rs = new ResultInfo();
		if(userId==null || StringUtils.isEmpty(userInfo)){
			logger.error("參數錯誤");
			rs.setResult_code(2501);
			rs.setResult_detail("參數錯誤");
			return JSON.toJSONString(rs);
		}
		String key = ADMINWEB_USER+userId;
		redisService.set(key , userInfo,LIVETIME);
		rs.setResult_code(0);
		rs.setResult_detail("success");
		return JSON.toJSONString(rs);
	}
	
	public String get(JSONObject param){
		Long userId = param.getLong("user_id");
		String key = ADMINWEB_USER+userId;
		ResultInfo  rs = new ResultInfo();
		String user = redisService.get(key);
		rs.setResult_code(0);
		rs.setResult_detail("success");
		rs.setResult_data(user);
		return JSON.toJSONString(rs);
	}
	
	public String delete(JSONObject param){
		Long userId = param.getLong("user_id");
		String key = ADMINWEB_USER+userId;
		ResultInfo  rs = new ResultInfo();
		long isDel = redisService.del(key);
		rs.setResult_code(0);
		rs.setResult_detail("success");
		return JSON.toJSONString(rs);
	}

}

  

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM