Java 搭建Redis链接池工具类

    Redis是一个开源的使用ANSI C语言编写、遵照BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。在编码过程当中,可能一些计算或者取数的量很大,超过了HTTP协议设置的超时时间,这就须要Redis来处理了。java

    首先咱们须要搭建好Redis服务器,这里暂不作介绍。当服务器搭建好,接口已经写好,咱们该怎么去使用呢?下面咱们就经过建立一个Redis链接池的方式,来更方便的使用Redis。建立Redis工具类,首先导入jar,如:jedis-2.5.1.jar,代码以下:redis

public class RedisUtil{
  
   //Redis服务器IP
   private static String URL = "10.11.12.13";
   //Redis的端口号
   private static int PORT = 6379;
   //可用链接实例的最大数目,默认值为8
   private static int MAX_ACTIVE = 1024;
   //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8
   private static int MAX_IDLE = 200;
   //等待可用链接的最大时间,单位毫秒,默认值为-1,表示永不超时
   //若是超过等待时间,则直接抛出JedisConnectionException
   private static int MAX_WAIT = 20000;
   private static int TIMEOUT = 10000;
   //在borrow一个jedis实例时,是否提早进行validate操做,若是为true,则获得的jedis实例均是可用的
   private static boolean TEST_ON_BORROW = true;
   
   private static JedisPool jedisPool = null;

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

   /**
    * 获取Jedis实例
    * @return
    */
   public synchronized static Jedis getJedis() {
        Jedis redis = null;
        try{
           if(jedisPool != null){
              redis = jedisPool.getResource();
              return redis;
           }else{
              return null;
           }
        } catch (Exception e){
             e.printStackTrace();
             return null;
        }
   }

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

   /*
	* Test
	*/
   @Test
   public void main(){
       //测试Redis服务器的链接
       Jedis jedis = new Jedis(URL,6379);
       System.out.println(jedis.ping());
       //测试Redis取数(需先肯定redis key存储类型,这里是hashMap)
       Jedis jedis = getJedis();
       Map<String, String> ss = jedis.hgetAll("TEST");
   }
}

    上面是Java类中对Redis的使用,具体的接口可根据本身须要定义。数据库

相关文章
相关标签/搜索