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