redis 操作

来源:互联网 发布:建筑工程会计记账软件 编辑:程序博客网 时间:2024/06/03 19:45

1、创建 java project 工程,添加 jar 包

jedis-2.1.0.jar

commons-pool-1.5.4.jar


2、创建 RedisUtil 类,对 redis 连接池操作

package com.test;import redis.clients.jedis.Jedis;import redis.clients.jedis.JedisPool;import redis.clients.jedis.JedisPoolConfig;public class RedisUtil {//Redis服务器IP    private static String ADDR = "10.10.10.26";        //Redis的端口号    private static int PORT = 6379;        //访问密码    private static String AUTH = null;        //可用连接实例的最大数目,默认值为8;    //如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。    private static int MAX_ACTIVE = 1024;        //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。    private static int MAX_IDLE = 200;        //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;    private static int MAX_WAIT = 10000;        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 jpc = new JedisPoolConfig();        jpc.setMaxActive(MAX_ACTIVE);        jpc.setMaxIdle(MAX_IDLE);        jpc.setMaxWait(MAX_WAIT);        jpc.setTestOnBorrow(TEST_ON_BORROW);        jedisPool = new JedisPool(jpc,ADDR,PORT,TIMEOUT,AUTH);} catch (Exception e) {e.printStackTrace();}    }        /**     * 获取Jedis实例     * @return     */    public synchronized static Jedis getJedis(){    try {if (jedisPool != null) {Jedis resource = jedisPool.getResource();return resource;}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);}    }}

3、使用 Junit 测试,类是 TestRedis

package com.test;import java.util.HashMap;import java.util.List;import java.util.Map;import org.junit.Before;import org.junit.Test;import redis.clients.jedis.Jedis;public class TestRedis {private Jedis jedis;@Beforepublic void setup(){//连接redis服务器,10.10.10.26:6379jedis = new Jedis("10.10.10.26", 6379);//权限认证//jedis.auth("admin");}/** * redis操作String */@Testpublic void testString(){jedis.set("username","java");System.out.println("username:"+jedis.get("username"));jedis.append("username", ", hello!");//追加System.out.println(jedis.get("username"));jedis.del("username");System.out.println("删除的键"+jedis.get("username"));jedis.mset("username","jack","age","23","sex","man");//多个键值对设置sjedis.incr("age");//对年龄加1操作System.out.println(jedis.get("age"));}/** * redis操作Map */@Testpublic void testMap(){Map<String,String> user = new HashMap<String, String>();user.put("name", "jack");user.put("age", "22");user.put("sex", "man");user.put("loves", "foot");jedis.hmset("user", user);List<String> values = jedis.hmget("user", "name","age","sex","loves");System.out.println(values.toString());jedis.hdel("user", "age");System.out.println(jedis.hmget("user","age")); //因为删除了,所以返回的是null  System.out.println(jedis.hlen("user"));//返回key为user的键中存放的值的个数3System.out.println(jedis.exists("user"));//是否存在key为user的记录 返回trueSystem.out.println(jedis.hkeys("user"));//返回map对象中的所有keySystem.out.println(jedis.hvals("user"));//返回map对象中的所有value}/** * redis操作List */@Testpublic void testList(){//向key username中存放三条数据  jedis.lpush("username","J2SE");jedis.lpush("username","J2EE");jedis.lpush("username", "J2ME");//再取出所有数据jedis.lrange是按范围取出,          // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有 System.out.println(jedis.lrange("username",0, -1));//移除所有的内容  jedis.del("username");System.out.println(jedis.lrange("username",0,-1));}/** * redis操作Set */@Testpublic void testSet(){//saddjedis.sadd("username", "张三");jedis.sadd("username", "李四");jedis.sadd("username", "王五");jedis.sadd("username", "赵六");System.out.println(jedis.scard("username"));//集合的个数System.out.println(jedis.sismember("username", "赵六"));System.out.println(jedis.smembers("username"));//所有的valuesSystem.out.println(jedis.srandmember("username"));//随机抽取System.out.println(jedis.srem("username", "赵六"));//移除}/** * redis操作排序 */@Testpublic void test() throws InterruptedException{//jedis 排序          //注意,此处的rpush和lpush是List的操作。是一个双向链表(从表现来看的)     jedis.del("username");//先清除数据,再加入数据进行测试      jedis.rpush("username", "2");          jedis.lpush("username","8");          jedis.lpush("username","3");          jedis.lpush("username","9");        System.out.println(jedis.lrange("username",0,-1));        System.out.println(jedis.sort("username"));//排序结果        System.out.println(jedis.lrange("username",0,-1));}@Testpublic void testRedisPool(){RedisUtil.getJedis().set("username", "java");System.out.println(RedisUtil.getJedis().get("username"));RedisUtil.returnResource(jedis);}}