@coldxiangyu
2017-04-06T09:26:59.000000Z
字数 1841
阅读 1575
redis
Jedis是Redis官方首选的Java客户端开发包,有了它我们就可以愉快的用java操作redis了。
接下来搭建一个测试jedis的工程,如下:
需要引入包,jedis-2.9.0.jar以及commons-pool2-2.3.jar
首先编写Junit测试类,测试redis连通性。
代码如下:
package com.lxy.test;
import org.junit.Test;
import redis.clients.jedis.Jedis;
public class JedisTest {
//书写测试类
@Test
public void TestJedis(){
//创建jedis对象,相当于创建了一个客户端和reidis服务器的链接。需要ip和端口号,IP就是安装有redis服务的linux服务器的地址,端口号默认为6379
Jedis jedis= new Jedis("127.0.0.1",6379);
//ping redis服务器,这是它的一个方法,如果服务正常,会回复一个pong
String pong = jedis.ping();
System.out.println("如果服务器可用请返回pong,谢谢合作:"+pong);
//先用第一个键去取一次值,这个时候redis中没有数据返回应该是空的。
String value = jedis.get("key");
System.out.println("第一次访问的时候取到的值="+value);
//将数据存入reidis服务器中
jedis.set("key","第一次存入的值");
//将数据取出
value = jedis.get("key");
System.out.println("存入相应的值以后取到的值="+value);
//关闭和redis的链接
jedis.close();
}
}
结果如下:
对应服务器响应:
在实际应用中,这样是远远不够的,不能每次进行redis数据操作就单独建立连接。jedis提供了连接池的API,JedisPool。
以下为jedis连接池的测试类,写的比较简单:
package com.lxy.pool;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
public class RedisUtils {
private RedisUtils(){
}
private static JedisPool jedisPool = null;
//获取链接
public static synchronized Jedis getJedis(){
if(jedisPool==null){
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
//指定连接池中最大空闲连接数
jedisPoolConfig.setMaxIdle(10);
//链接池中创建的最大连接数
jedisPoolConfig.setMaxTotal(100);
//设置创建链接的超时时间
jedisPoolConfig.setMaxWaitMillis(2000);
//表示连接池在创建链接的时候会先测试一下链接是否可用,这样可以保证连接池中的链接都可用的。
jedisPoolConfig.setTestOnBorrow(true);
jedisPool = new JedisPool(jedisPoolConfig, "127.0.0.1", 6379);
}
return jedisPool.getResource();
}
//返回链接
public static void returnResource(Jedis jedis){
jedisPool.close();
}
}
之后,我把开始的测试类改成获取连接池连接进行redis操作:
@Test
public void TestJedisPool(){
Jedis jedis = RedisUtils.getJedis();
System.out.println("测试连通性:"+jedis.ping());
String value = jedis.get("key");
System.out.println("key="+value);
}
执行结果:
关于jedis的基本操作先介绍到这里,后续在项目中的具体应用及优化再进行补充说明。