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