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的使用,具體的接口可根據本身須要定義。數據庫

相關文章
相關標籤/搜索