Coin163

redis工具类封装RedisUtil

2016-03-25by coin, 次阅读
   RedisUtil 或JedisUtil封装了Jedis对象的获取以及简单的String类型的获取。
其它类型的操作可直接使用Jedis对象进行。

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

/**
 * Redis工具类
 * 
 */
public final class RedisUtil {
	// Redis服务器IP,这里可使用diamond获取
	private static String HOST = "192.168.0.2";
	// Redis的端口号
	private static int PORT =6379;
	// 可用连接实例的最大数目,默认值为8;
	// 如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。
	private static int MAX_ACTIVE = 50;
	// 控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
	private static int MAX_IDLE = 10;
	// 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;
	private static int MAX_WAIT = 5000;
	private static int TIMEOUT = 1000;

	// 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
	private static boolean TEST_ON_BORROW = true;

	private static JedisPool jedisPool = null;

	private RedisUtil() {

	}

	// //////////////////////////////////////////////////////////redis 操作函数

	public static Long incr(final String key) {
		Jedis jedis = null;
		try {
			jedis = getJedis();
			return jedis.incr(key);
		} finally {
			returnResource(jedis);
		}
	}

	public static String set(final String key, String value) {
		Jedis jedis = null;
		try {
			jedis = getJedis();
			return jedis.set(key, value);
		} finally {
			returnResource(jedis);
		}
	}
	
	/**
	 * 设置值和过期时间
	 * @param key
	 * @param value
	 * @param expireSeconds 单位秒
	 * @return
	 */
	public static String set(final String key, String value,int expireSeconds) {
		Jedis jedis = null;
		try {
			jedis = getJedis();
			return jedis.setex(key, expireSeconds, value);
		} finally {
			returnResource(jedis);
		}
	}

	public static String get(final String key) {
		Jedis jedis = null;
		try {
			jedis = getJedis();
			return jedis.get(key);
		} finally {
			returnResource(jedis);
		}
	}

	public static Long del(final String... keys) {
		Jedis jedis = null;
		try {
			jedis = getJedis();
			return jedis.del(keys);
		} finally {
			returnResource(jedis);
		}
	}

	/**
	 * 设置过期时间
	 * 
	 * @param key
	 * @param seconds
	 */
	public void expire(String key, int seconds) {
		if (seconds <= 0) {
			return;
		}
		Jedis jedis = getJedis();
		jedis.expire(key, seconds);
		returnResource(jedis);
	}

	// /////////////////////////////

	// /**
	// * 初始化Redis连接池
	// */
	// static {
	// try {
	// JedisPoolConfig config = new JedisPoolConfig();
	// config.setMaxActive(MAX_ACTIVE);
	// config.setMaxIdle(MAX_IDLE);
	// config.setMaxWait(MAX_WAIT);
	// config.setTestOnBorrow(TEST_ON_BORROW);
	// jedisPool = new JedisPool(config, HOST, PORT, TIMEOUT);
	// } catch (Exception e) {
	// e.printStackTrace();
	// }
	// }

	/**
	 * 建立连接池
	 * 
	 */
	private static void createJedisPool() {
		JedisPoolConfig config = new JedisPoolConfig();
		config.setMaxActive(MAX_ACTIVE);
		config.setMaxIdle(MAX_IDLE);
		config.setMaxWait(MAX_WAIT);
		config.setTestOnBorrow(TEST_ON_BORROW);
		jedisPool = new JedisPool(config, HOST, PORT, TIMEOUT);

	}

	/**
	 * 获取Jedis实例
	 * 
	 * @return
	 */
	public synchronized static Jedis getJedis() {
		if (jedisPool == null) {
			createJedisPool();
		}
		return jedisPool.getResource();

	}

	/**
	 * 释放jedis资源
	 * 
	 * @param jedis
	 */
	public static void returnResource(final Jedis jedis) {
		if (jedis != null) {
			jedisPool.returnResource(jedis);
		}
	}
}
------分隔线----------------------------