redis缓存存储、删除、查找、更新

1,实际工程代码

配置文件 bootstrap.properties

redis.database=0
redis.host={sc}
redis.port=6379

接口

package com.mylib.elba.cache.service;
import com.mylib.elba.cache.entity.CacheManage;
import com.mylib.Pageable;
import com.mylib.sql.QueryFilter;

/**
 * @author ljj
 *
 */
public interface CacheManageService {
       //存储一个对象进入redis
    String createCache(CacheManage cache);
       //根据过滤条件查询缓存,并返回分页
    Pageable getAllRedis(QueryFilter query, int page, int pageSize);
        //根据key值模糊查询,并返回分页(性能较好)
    Pageable getCache(String key, int page, int pageSize);
        //  改变存在redis中对象的某一个属性的值(state属性)
    void changeStateInval(String key);
    void changeStateVal(String key);
        //根据key删除
    void delCache(String key);
}

实现类

package com.mylib.elba.cache.service.impl;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Properties;
import java.util.Set;

import org.springframework.stereotype.Service;

import com.mylib.elba.cache.entity.CacheManage;
import com.mylib.elba.cache.inner.PropertyUtil;
import com.mylib.elba.cache.service.CacheManageService;
import mylib.Pageable;
import com.mylib.sql.Command;
import com.mylib.sql.QueryFilter;
import com.mylib.util.SerializeUtil;

import redis.clients.jedis.Jedis;

/**
 * @author ljj
 *
 */
@Service
public class CacheManageServiceImpl implements CacheManageService {

    private static String path = "";
    private static int port;
    private static int database;
    // 日期格式化
    private SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

    static {
        // 配置文件只加载一次
        Properties properties = PropertyUtil.loadProperties("bootstrap.properties");
        path = properties.getProperty("redis.host");
        port = Integer.parseInt(properties.getProperty("redis.port"));
        database = Integer.parseInt(properties.getProperty("redis.database"));
    }

    private Jedis redisInit() {
        Jedis redis = new Jedis(path, port);
        // redis的指定数据库
        redis.select(database);
        return redis;
    }

    @Override
    public Pageable getAllRedis(QueryFilter query, int page, int pageSize) {
        Jedis redis = redisInit();
        // 获取所有key
        Set keys = redis.keys("*");
        List list = new ArrayList();
        for (String key : keys) {
            byte[] value = redis.get(key.getBytes());
            Object object = SerializeUtil.unserialize(value);
            if (object != null) {
                CacheManage cache = (CacheManage) object;
                list.add(cache);
            }
        }
        redis.close();

        // 处理过滤查询
        List queryList = queryFromRedis(query, list);
        // 处理分页
        Pageable pageList = paging(queryList, page, pageSize);

        return pageList;
    }

    // 处理过滤查询
    public List queryFromRedis(QueryFilter query, List list) {
        List queryList = new ArrayList();
        for (CacheManage cache : list) {
            if (queryFlag(query, cache)) {
                queryList.add(cache);
            }
        }
        return queryList;
    }

    // 判断单个缓存是否符合过滤条件
    public boolean queryFlag(QueryFilter query, CacheManage cache) {
        for (Command command : query.getCommands()) {
            String comValue = command.getValue().toString();
            String comField = command.getField();
            if (comField.equals("root_System") && !cache.getRootSystem().contains(comValue)) {
                return false;
            }
            if (comField.equals("key") && !cache.getKey().contains(comValue)) {
                return false;
            }
            if (comField.equals("value") && !cache.getValue().contains(comValue)) {
                return false;
            }
            if (comField.equals("state")) {
                // 2表示全选
                if (!comValue.equals("2") && !cache.getState().equals(comValue)) {
                    return false;
                }
            }
            // 时间段
            if (comField.equals("end_Time")) {
                // 根据时间段查询
                if (comValue.equals("undefined~undefined")) {
                    continue;
                }
                Date date = cache.getEndTime();
                if (null == date) {
                    return false;
                }
                String[] array = comValue.toString().split("~");
                String datefrom = array[0];
                String dateto = array[1];
                try {
                    if (!datefrom.equals("undefined") && sdf.parse(datefrom).getTime() > date.getTime()) {
                        return false;
                    }
                    if (!dateto.equals("undefined") && sdf.parse(dateto).getTime() < date.getTime()) {
                        return false;
                    }
                } catch (ParseException e) {
                    e.printStackTrace();
                }
            }
        }
        return true;
    }

    // 将list分页
    public Pageable paging(List list, int page, int pageSize) {
        if (list != null && list.size() > 0) {
            int totalcount = list.size();
            int fromIndex = (page - 1) * pageSize;
            int toIndex = page * pageSize;
            if (fromIndex > totalcount) {
                return null;
            }
            if (toIndex > totalcount) {
                toIndex = totalcount;
            }
            List subList = list.subList(fromIndex, toIndex);
            Pageable pageList = new Pageable(page, pageSize, totalcount, subList);
            return pageList;
        } else {
            return null;
        }

    }

    @Override
    public void changeStateInval(String key) {
        Jedis redis = redisInit();
        // 有效(1)变无效(0)
        byte[] value = redis.get(key.getBytes());
        Object object = SerializeUtil.unserialize(value);
        if (object != null) {
            CacheManage cache = (CacheManage) object;
            cache.setState("0");
            cache.setEndTime(new Date());
            // 删除之前的值
            if (redis.exists(key)) {
                redis.del(key);
            }
            redis.set(cache.getKey().getBytes(), SerializeUtil.serialize(cache), "NX".getBytes());
        }
        redis.close();
    }

    @Override
    public void changeStateVal(String key) {
        Jedis redis = redisInit();
        // 无效(0)变无效(1)
        byte[] value = redis.get(key.getBytes());
        Object object = SerializeUtil.unserialize(value);
        if (object != null) {
            CacheManage cache = (CacheManage) object;
            cache.setState("1");
            cache.setEndTime(null);
            // 删除之前的值
            if (redis.exists(key)) {
                redis.del(key);
            }
            redis.set(cache.getKey().getBytes(), SerializeUtil.serialize(cache), "NX".getBytes());
        }
        redis.close();
    }

    @Override
    public void delCache(String key) {
        Jedis redis = redisInit();
        if (redis.exists(key)) {
            redis.del(key);
        }
        redis.close();
    }

    // 建立缓存对外接口实现
    @Override
    public String createCache(CacheManage cache) {
        Jedis redis = redisInit();
        cache.setCreateDate(new Date());
        // 状态 :0 无效,1有效,存的时候默认有效
        cache.setState("1");

        // 均为永久保存
        String result = redis.set(cache.getKey().getBytes(), SerializeUtil.serialize(cache), "NX".getBytes());
        redis.close();
        return result;
    }

    // 获取缓存对外接口实现
    @Override
    public Pageable getCache(String key, int page, int pageSize) {
        // 获取所有key
        Jedis redis = redisInit();

        Set keys = redis.keys("*" + key + "*");
        List list = new ArrayList();
        for (String itm : keys) {
            byte[] value = redis.get(itm.getBytes());
            Object object = SerializeUtil.unserialize(value);
            if (object != null) {
                CacheManage cache = (CacheManage) object;
                list.add(cache);
            }
        }
        redis.close();

        // 处理分页
        Pageable pageList = paging(list, page, pageSize);

        return pageList;
    }

}

2,redis储存对象需要用到的序列化类

package com.mylib.util;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;

public class SerializeUtil {
    public static byte[] serialize(Object object) {
        if (object == null) {
            return new byte[0];
        } else {
            ObjectOutputStream oos = null;
            ByteArrayOutputStream baos = null;

            try {
                baos = new ByteArrayOutputStream();
                oos = new ObjectOutputStream(baos);
                oos.writeObject(object);
                byte[] e = baos.toByteArray();
                return e;
            } catch (Exception arg3) {
                throw new RuntimeException(arg3.getMessage(), arg3);
            }
        }
    }

    public static Object unserialize(byte[] bytes) {
        if (bytes != null && bytes.length != 0) {
            ByteArrayInputStream bais = null;

            try {
                bais = new ByteArrayInputStream(bytes);
                ObjectInputStream e = new ObjectInputStream(bais);
                return e.readObject();
            } catch (Exception arg2) {
                throw new RuntimeException(arg2.getMessage(), arg2);
            }
        } else {
            return null;
        }
    }
}

你可能感兴趣的:(redis缓存存储、删除、查找、更新)