redis連接池 jedis-2.9.0.jar+commons-pool2-2.4.2.jar


java使用Redis連接池 

jar包為 jedis-2.9.0.jar+commons-pool2-2.4.2.jar

jar下載地址

  1 package com.test;
  2 
  3 import redis.clients.jedis.Jedis;
  4 import redis.clients.jedis.JedisPool;
  5 import redis.clients.jedis.JedisPoolConfig;
  6 
  7 public  class RedisUtil {
  8     //Redis服務器IP
  9     private static String ADDR = "192.168.0.41";
 10     
 11     //Redis的端口號
 12     private static int PORT = 6379;
 13     
 14     //訪問密碼
 15     private static String AUTH = "admin";
 16     
 17     //可用連接實例的最大數目,默認值為8;
 18     //如果賦值為-1,則表示不限制;如果pool已經分配了maxActive個jedis實例,則此時pool的狀態為exhausted(耗盡)。
 19     private static int MAX_TOTAL = 8;
 20     
 21     //最小空閑連接數, 默認0
 22     private static int MIN_IDLE=0;
 23     
 24     //控制一個pool最多有多少個狀態為idle(空閑的)的jedis實例,默認值也是8。
 25     //最大空閑連接數, 默認8個
 26     private static int MAX_IDLE = 8;
 27     
 28     //獲取連接時的最大等待毫秒數(如果設置為阻塞時BlockWhenExhausted),如果超時就拋異常, 小於零:阻塞不確定的時間,  默認-1
 29     //等待可用連接的最大時間,單位毫秒,默認值為-1,表示永不超時。如果超過等待時間,則直接拋出JedisConnectionException;
 30     private static int MAX_WAIT = -1;
 31     
 32     private static int TIMEOUT = 10000;
 33     
 34     //連接耗盡時是否阻塞, false報異常,ture阻塞直到超時, 默認true
 35     private static boolean BLOCK_WHEN_EXHAUSTED = false;
 36     
 37     //設置的逐出策略類名, 默認DefaultEvictionPolicy(當連接超過最大空閑時間,或連接數超過最大空閑連接數)
 38     private static String EVICTION_POLICY_CLASSNAME="org.apache.commons.pool2.impl.DefaultEvictionPolicy";
 39     
 40     //是否啟用pool的jmx管理功能, 默認true
 41     private static boolean JMX_ENABLED=true;
 42    
 43     //MBean ObjectName = new ObjectName("org.apache.commons.pool2:type=GenericObjectPool,name=" + "pool" + i); 默認為"pool", JMX不熟,具體不知道是干啥的...默認就好.
 44     private static String JMX_NAME_PREFIX="pool";
 45     
 46     //是否啟用后進先出, 默認true
 47     private static boolean LIFO=true;
 48     
 49     //逐出連接的最小空閑時間 默認1800000毫秒(30分鍾)
 50     private static long MIN_EVICTABLE_IDLE_TIME_MILLIS=1800000L;
 51     
 52     //對象空閑多久后逐出, 當空閑時間>該值 且 空閑連接>最大空閑數 時直接逐出,不再根據MinEvictableIdleTimeMillis判斷  (默認逐出策略)   
 53     private static long SOFT_MIN_EVICTABLE_IDLE_TIME_MILLIS=1800000L;
 54     
 55     //每次逐出檢查時 逐出的最大數目 如果為負數就是 : 1/abs(n), 默認3
 56     private static int NUM_TESTS_PER_EVICYION_RUN=3;
 57     
 58     //在borrow一個jedis實例時,是否提前進行validate操作;如果為true,則得到的jedis實例均是可用的;
 59     //在獲取連接的時候檢查有效性, 默認false
 60     private static boolean TEST_ON_BORROW = false;
 61     
 62     //在空閑時檢查有效性, 默認false
 63     private static boolean TEST_WHILEIDLE=false;
 64     
 65     //逐出掃描的時間間隔(毫秒) 如果為負數,則不運行逐出線程, 默認-1
 66     private static long TIME_BERWEEN_EVICTION_RUNS_MILLIS=-1;
 67     
 68     private static JedisPool jedisPool = null;
 69     
 70     /**
 71      * 初始化Redis連接池
 72      */
 73     static {
 74         try {
 75             JedisPoolConfig config = new JedisPoolConfig();
 76             config.setBlockWhenExhausted(BLOCK_WHEN_EXHAUSTED);
 77             config.setEvictionPolicyClassName(EVICTION_POLICY_CLASSNAME); 
 78             config.setJmxEnabled(JMX_ENABLED);
 79             config.setJmxNamePrefix(JMX_NAME_PREFIX);
 80             config.setLifo(LIFO);
 81             config.setMaxIdle(MAX_IDLE);
 82             config.setMaxTotal(MAX_TOTAL);
 83             config.setMaxWaitMillis(MAX_WAIT);
 84             config.setMinEvictableIdleTimeMillis(MIN_EVICTABLE_IDLE_TIME_MILLIS);
 85             config.setMinIdle(MIN_IDLE);
 86             config.setNumTestsPerEvictionRun(NUM_TESTS_PER_EVICYION_RUN);
 87             config.setSoftMinEvictableIdleTimeMillis(SOFT_MIN_EVICTABLE_IDLE_TIME_MILLIS);
 88             config.setTestOnBorrow(TEST_ON_BORROW);
 89             config.setTestWhileIdle(TEST_WHILEIDLE);
 90             config.setTimeBetweenEvictionRunsMillis(TIME_BERWEEN_EVICTION_RUNS_MILLIS);
 91             
 92             jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH);
 93         } catch (Exception e) {
 94             e.printStackTrace();
 95         }
 96     }
 97     
 98     /**
 99      * 獲取Jedis實例
100      * @return
101      */
102     public synchronized static Jedis getJedis() {
103         try {
104             if (jedisPool != null) {
105                 Jedis resource = jedisPool.getResource();
106                 return resource;
107             } else {
108                 return null;
109             }
110         } catch (Exception e) {
111             e.printStackTrace();
112             return null;
113         }
114     }
115 
116     /**
117      * 釋放jedis資源
118      * @param jedis
119      */
120     public static void close(final Jedis jedis) {
121         if (jedis != null) {
122             jedis.close();
123         }
124     }
125 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM