Redis使用工具类

项目中引入了Redis。虽然Jfinal整合了Redis,但是使用自身的序列化机制效率并不是很高,目前比较好的序列化机制是google的Protostuff,所以这里采用Protostuff编写一个Redis工具类。代码如下:

public class RedisDao {
	private final Logger logger = LoggerFactory.getLogger(this.getClass());
	
	private final JedisPool jedisPoll;
	
	public RedisDao(String ip, int port){
		jedisPoll = new JedisPool(ip, port);
	}
    //以Users为例
	private RuntimeSchema<Users> schema = RuntimeSchema.createFrom(Users.class);
	//获取对象缓存
	public Object get(String usersId) {
		// redis操作
		try {
			Jedis jedis = jedisPoll.getResource();
			try {
			//java自带序列化机制效率不高,采用google protostuff实现自身序列化机制
			String  key = "userId:"+ usersId;
			//实现序列化机制,对象必须为pojo类型
			byte[] bytes = jedis.get(key.getBytes());
			
			if(bytes != null){
				Users users = schema.newMessage();
				ProtostuffIOUtil.mergeFrom(bytes, users, schema);
				return users;
			}						
			} finally {
				jedis.close();
			}
		} catch (Exception e) {
			// TODO: handle exception
			logger.error(e.getMessage(), e);
		}
		return null;
	}
	
	//将对象放入缓存
	public Object set(Users users){
	  try {
		Jedis jedis = jedisPoll.getResource();
		try {
			String key = "userId:"+ users.getAccid();
			byte[] bytes = ProtostuffIOUtil.toByteArray(users, schema, 
					LinkedBuffer.allocate(LinkedBuffer.DEFAULT_BUFFER_SIZE));
			//超时缓存
			int timeout = 60*60;
			//返回结果
			String result  = jedis.setex(key.getBytes(), timeout, bytes);
		    return result;
	    } finally {
			jedis.close();
		}	
	    }catch (Exception e) {
		// TODO: handle exception
	    logger.error(e.getMessage(), e);
	   }
	   return null;	
}
}

初始化代码如下:
RedisDao redisDao = new RedisDao("localhost", 6379);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值