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

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

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的使用,具体的接口可根据自己需要定义。

04-19 14:49