Jedis操作set&sortedset和Jedis连接池&Jedis连接池工具类

Jedis操作set&sortedset

set:

    /**
     * set
     */
    @Test
    public void test5(){
        //1.获取连接
        Jedis jedis = new Jedis();//如果使用空参构造,默认值"localhost",6379端口
        //set存储
        jedis.sadd("myset","java","php","c++");
        //set获取
        Set<String> myset = jedis.smembers("myset");
        System.out.println(myset);


        //关闭连接
        jedis.close();
    }

sortedset:

/**
     * sortedset
     */
    @Test
    public void test6(){
        //1.获取连接
        Jedis jedis = new Jedis();//如果使用空参构造,默认值"localhost",6379端口
        //sortedset存储
        jedis.zadd("mysort",3,"张三");
        jedis.zadd("mysort",30,"李四");
        jedis.zadd("mysort",25,"王五");
        //sortedset获取
        Set<String> mysort = jedis.zrange("mysort", 0, -1);
        System.out.println(mysort);

        //关闭连接
        jedis.close();
    }

Jedis连接池

    /**
     * jedis连接池的使用
     */
    @Test
    public void test7(){
        //创建一个配置对象
        JedisPoolConfig config = new JedisPoolConfig();
        config.setMaxTotal(50);
        config.setMaxIdle(10);
        //创建Jedis连接池对象
        JedisPool jedisPool = new JedisPool(config, "localhost", 6379);
        //获取连接
        Jedis jedis = jedisPool.getResource();
        //使用
        jedis.set("hehe","haha");
        //关闭  归还到连接池中
        jedis.close();
    }

 

 相关的一些配置:

#最大活动对象数     
redis.pool.maxTotal=1000    
#最大能够保持idel状态的对象数      
redis.pool.maxIdle=100  
#最小能够保持idel状态的对象数   
redis.pool.minIdle=50    
#当池内没有返回对象时,最大等待时间    
redis.pool.maxWaitMillis=10000    
#当调用borrow Object方法时,是否进行有效性检查    
redis.pool.testOnBorrow=true    
#当调用return Object方法时,是否进行有效性检查    
redis.pool.testOnReturn=true  
#“空闲链接”检测线程,检测的周期,毫秒数。如果为负值,表示不运行“检测线程”。默认为-1.  
redis.pool.timeBetweenEvictionRunsMillis=30000  
#向调用者输出“链接”对象时,是否检测它的空闲超时;  
redis.pool.testWhileIdle=true  
# 对于“空闲链接”检测线程而言,每次检测的链接资源的个数。默认为3.  
redis.pool.numTestsPerEvictionRun=50  
#redis服务器的IP    
redis.ip=xxxxxx  
#redis服务器的Port    
redis1.port=6379

Jedis连接池工具类

配置文件:

host=127.0.0.1
#localhost=127.0.0.1
port=6379
maxTotal=50
maxIdle=10

Jedis工具类

package cn.peng.web.jedis.util;

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

import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;

/**
 *
 *JedisPool工具类
 *  加载配置文件,配置连接池的参数
 *  提供获取连接的方法
 *
 *
 */
public class JedisPoolUtils {
    private static JedisPool jedisPool;

    static {
        //读取配置文件
        InputStream is = JedisPoolUtils.class.getClassLoader().getResourceAsStream("jedis.properties");
        //创建Properties
        Properties pro = new Properties();
        //关联文件
        try {
            pro.load(is);
        } catch (IOException e) {
            e.printStackTrace();
        }
        //获取数据,设置到JedisPoolConfig中
        JedisPoolConfig config = new JedisPoolConfig();
        config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));
        config.setMaxIdle(Integer.parseInt(pro.getProperty("maxIdle")));
        //初始化JedisPool
        jedisPool = new JedisPool(config,pro.getProperty("host"),Integer.parseInt(pro.getProperty("port")));
    }
    /**
     * 获取连接方法
     */
    public static Jedis getJedis(){
        return jedisPool.getResource();
    }
}

测试:

    /**
     * jedis连接池工具类的使用
     */
    @Test
    public void test8(){
        //通过连接池工具类获取
        Jedis jedis = JedisPoolUtils.getJedis();
        //使用
        jedis.set("hehe","qqq");
        //关闭  归还到连接池中
        jedis.close();
    }

 NullPointException可以把配置文件这样进行修改(或重启IDEA)

localhost=127.0.0.1

这里也要对应着进行修改

 

posted @ 2022-08-22 10:03  魔光领域  阅读(45)  评论(0编辑  收藏  举报