当前位置: 首页 > 工具软件 > Jedis > 使用案例 >

jedis简介和使用

相德宇
2023-12-01

1.jedis简介

jedis是一个java实现的redis客户端连接工具。常用的还有redisson,jedis跟接近于原生的操作,而redisson跟适合用于分布式,提供了分布式锁,以及其他多种数据结构。
jedis使用非常简单
直接引入依赖

<dependency>
			<groupId>redis.clients</groupId>
			<artifactId>jedis</artifactId>
			<version>2.9.0</version>
		</dependency>
Jedis jedis = new Jedis("locahost",6379);

jedis使用完后记得调用其close方法释放其资源,jedis是线程不完全,多线程使用同一个jedis实例,会出现并发问题,原因是底层共用了一个输入输出流。避免这个问题每次使用可以new 一个新的Jedis实例,但是创建实例的代价是昂贵的,jedis提供,jedisPool,和数据库池,线程池的思想类似,就是保存一定的jedis实例,需要的话就拿来用。

2.简单使用

package com.redis;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

import java.io.*;
import java.net.URL;
import java.util.List;
import java.util.Properties;

public class JedisUtil {

    private final static Logger LOGGER = LoggerFactory.getLogger(JedisUtil.class);
    private JedisPool jedisPool = null;
    /**
     * 不存在才设置
     */
    public static final String NX = "NX";
    /**
     * 存在才设置
     */
    public static final String XX = "XX";
    //秒
    public static final String EX = "EX";
    //毫秒
    public static final String PX = "PX";

    static {

    }

    public JedisUtil() throws IOException {
        Properties properties = new Properties();
        URL resource = JedisUtil.class.getResource("redis.properties");
        properties.load(resource.openStream());
        JedisPoolConfig config = new JedisPoolConfig();
        Integer maxActive = Integer.parseInt(properties.getProperty("jedis.pool.maxActive"));
        Integer maxIdle = Integer.parseInt(properties.getProperty("jedis.pool.maxIdle"));
        Long maxWait = Long.parseLong(properties.getProperty("jedis.pool.maxWait"));
        Boolean testOnBorrow = Boolean.valueOf(properties.getProperty("jedis.pool.testOnBorrow"));
        Boolean testOnReturn = Boolean.valueOf(properties.getProperty("jedis.pool.testOnReturn"));
        config.setMaxTotal(maxActive);
        config.setMaxIdle(maxIdle);
        config.setMaxWaitMillis(maxWait);
        config.setTestOnBorrow(testOnBorrow);
        config.setTestOnReturn(testOnReturn);
        jedisPool = new JedisPool(config,properties.getProperty("jedis.pool.ipAddress"),Integer.parseInt(properties.getProperty("jedis.pool.port")));
    }


    private Jedis getJedis(){
        return jedisPool.getResource();
    }

    public String set(byte[] key, byte[] value, String nxxx, String expx,
                    long time){
        Jedis jedis = null;
        try {
            jedis = jedisPool.getResource();
            return jedis.set(key,value,nxxx.getBytes("utf-8"),expx.getBytes("utf-8"),time);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnObject(jedis);
        }
        return null;
    }


    public String setString(String key,String val){
        Jedis jedis = null;
        try {
            jedis = jedisPool.getResource();
            return jedis.set(key,val);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnObject(jedis);
        }
        return  null;
    }

    /**
     * 设置集合值
     * @param key
     * @param val
     * @return
     */
    public Long lpush(byte[] key,byte[] ... val){
        Jedis jedis = null;
        try {
            jedis = jedisPool.getResource();
            return jedis.lpush(key,val);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnObject(jedis);
        }
        return  null;
    }

    /**
     * 设置集合值
     * @param key
     * @return
     */
    public List<byte[]> getAllListValues(byte[] key){
        Jedis jedis = null;
        try {
            jedis = jedisPool.getResource();
            Object vals = jedis.eval("local len = redis.call('llen',KEYS[1]) return redis.call('lrange',KEYS[1],0,len)".getBytes(),1,key);
            return (List<byte[]>) vals;
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnObject(jedis);
        }
        return  null;
    }


    public String getString(String key){
        Jedis jedis = null;
        try {
            jedis = jedisPool.getResource();
            return jedis.get(key);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnObject(jedis);
        }
        return  null;
    }

    /**
     * 返回删除的个数
     * @param key
     * @return
     */
    public Long del(byte[] key){
        Jedis jedis = null;
        try {
            jedis = jedisPool.getResource();
            return jedis.del(key);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnObject(jedis);
        }
        return  null;
    }

    public byte[] get(byte[] key){
        Jedis jedis = null;
        try {
            jedis = jedisPool.getResource();
            return jedis.get(key);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnObject(jedis);
        }
        return  null;
    }


    private void returnObject(Jedis jedis){
        if(jedis != null){
            jedis.close();
        }
    }


    /**
     * 序列化
     * @param obj
     * @return
     */
    public static byte [] serialize(Object obj){
        ObjectOutputStream objectOutputStream=null;
        ByteArrayOutputStream byteArrayOutputStream=null;
        try {
            byteArrayOutputStream=new ByteArrayOutputStream();
            objectOutputStream=new ObjectOutputStream(byteArrayOutputStream);
            objectOutputStream.writeObject(obj);
            byte[] bytes=byteArrayOutputStream.toByteArray();
            return bytes;
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }

    //反序列化
    public static Object unSerizlize(byte[] byt){
        ObjectInputStream objectInputStream=null;
        ByteArrayInputStream bis=null;
        bis=new ByteArrayInputStream(byt);
        try {
            objectInputStream=new ObjectInputStream(bis);
            Object obj=objectInputStream.readObject();
            return obj;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }

}


 类似资料: