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的使用,具体的接口可根据本身须要定义。数据库