redis学习

第三章:jedis的使用

2018-01-22  本文已影响54人  FantJ

Jedis是什么?

那jedis就是集成了redis的一些命令操作,封装了redis的java客户端。提供了连接池管理。一般不直接使用jedis,而是在其上在封装一层,作为业务的使用。如果用spring的话,可以看看spring 封装的 redis Spring Data Redis
·###Jedis基本使用

//生成一个Jedis对象,这个对象负责和指定Redis节点进行通信
Jedis jedis = new Jedis("127.0.0.1",6379);
//jedis执行set操作
jedis.set("hello","world");
//jedis执行get操作
String value = jedis.get("hello");
//incr key 自增1,如果key不存在,自增后get(key)=1
jedis.incr("counter");
//2.hash
jedis.hset("myhash","f1","v1");
jedis.hset("myhash","f2","v2");
//hash输出结果
jedis.hgetAll("myhash");
//3.list
jedis.rpush("mylist","1");
jedis.rpush("mylist","2");
jedis.rpush("mylist","3");
//输出结果[1,2,3]
jedis.lrange("mylist",0,-1);
//4.set
jedis.sadd("myset","a");
jedis.sadd("myset","b");
jedis.sadd("myset","c");
//输出结果
jedis.smembers("myset");
//5.zset
jedis.zadd("myzset",1,"jiao");
jedis.zadd("myzset",2,"fant");
jedis.zadd("myzset",3,"j");
//输出结果
jedis.zrangeWithScores("myzset",0,-1);

Jedis 连接池

  1. 直接连接
  1. Jedis连接池

Redis连接池工具类 RedisPool.java

package com.answer.admin.util.redis;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

/**
 * Redis连接池工具
 * Created by Fant.J.
 * 2017/10/24 20:55
 */
public class RedisPool {

    private static JedisPool jedisPool = null;
    private static Jedis jedis;
    static {
        jedis = getJedisPool().getResource();
    }
    /**
     * 构建redis连接池
     */
    public static JedisPool getJedisPool(){
        if (jedisPool == null){
            JedisPoolConfig config = new JedisPoolConfig();
            config.setMaxTotal(1024);//可用连接实例的最大数目,如果赋值为-1,表示不限制
            config.setMaxIdle(5);// 控制一个Pool最多有多少个状态为idle(空闲的)jedis实例,默认值也是8
            config.setMaxWaitMillis(1000*100);// 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时/如果超过等待时间,则直接抛出异常
            config.setTestOnBorrow(true);// 在borrow一个jedis实例时,是否提前进行validate操作,如果为true,则得到的jedis实例均是可用的
            jedisPool = new JedisPool(config, "192.168.218.129", 6379);
        }
        return jedisPool;
    }
    /**
     * 释放redis资源
     */
    public static void returnResource(Jedis jedis){
        if(jedis != null){
            jedis.close();
        }
    }
}

使用

package com.answer.admin.util.redis;

import org.junit.Test;
import org.springframework.dao.DataAccessException;
import org.springframework.data.redis.connection.RedisConnection;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core.RedisTemplate;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;

/**
 * Created by Fant.J.
 * 2017/10/24 20:48
 */

public class RedisTest {
    /** 普通用法 */
    @Test
    public void redisLearn(){
        Jedis jedis = new Jedis("192.168.218.129",6379);
        String result = jedis.get("hello");
        System.out.println(result);
    }
    /** 连接池用法,切记操作结束要施放资源 */
    @Test
    public void redisPoolLearn(){
        String value = "hello";
        String result = null;
        Jedis jedis = null;
        try {
            JedisPool jedisPool = RedisPool.getJedisPool();
            jedis = jedisPool.getResource();
            result = jedis.get(value);
        }catch (Exception e){
            RedisPool.returnResource(jedis);//施放资源
            e.printStackTrace();
        }finally {
            RedisPool.returnResource(jedis);
        }
        System.out.println(result);
    }
}

上一篇 下一篇

猜你喜欢

热点阅读