首页 > 其他分享 >Jedis操作set&sortedset和Jedis连接池&Jedis连接池工具类

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

时间:2022-08-22 10:12:12浏览次数:61  
标签:set redis jedis 连接池 Jedis pool

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

这里也要对应着进行修改

 

搜索

复制

标签:set,redis,jedis,连接池,Jedis,pool
From: https://www.cnblogs.com/pengtianyang/p/16611877.html

相关文章

  • Jedis操作redis中的数据结构
    哈希类型hash:map格式hsethgethgetAll /***hash数据结构操作*/@Testpublicvoidtest3(){//1、获取连接Jedisjedis=......
  • Jedis快速入门和操作string
    Jedis快速入门Jedis:一款java操作redis数据库的工具使用步骤:1、下载jedis的jar包2、使用/***jedis的测试类*/publicclassJedisTest{/**......
  • Jedis快速入门和Jedis操作string
    Jedis快速入门Jedis:是一款java操作redis数据库的工具使用步骤:1.下载Jedis的jar包2.使用这两个jar包导入项目中 编写一个测试类JedisTest:/***Jedis的......
  • redis命令操作list&set&sortedset和redis通用命令
    redis命令操作list&set&sortedset列表类型 list:可以添加一个元素到列表的头部(左边)或者尾部(右边)1.添加:lpush key value:将元素加入列表左边rpus......
  • 大家都能看得懂的源码 - ahooks useSet 和 useMap
    本文是深入浅出ahooks源码系列文章的第十篇,该系列已整理成文档-地址。觉得还不错,给个 star 支持一下哈,Thanks。今天我们来聊聊ahooks中对Map和Set类型进行状态......
  • 2022-8-20 数据库连接池
    1.概念:其实就是一个容器(集合),存放数据库连接的容器。当系统初始化好后,容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,从容器中获取连接对象,用户访问完之......
  • 2022-08-20 第二小组 张晟源(数据库连接池,queryRunner)
    JDBC(数据库连接池,queryRunner)一,数据库连接池Connection是一个稀有资源,一个连接就创造了一个资源同时在线人很多,服务器可能崩溃1.设置只有自己2.服务器人数限制,设置排......
  • Kubernetes学习笔记(十三):Daemon Sets
    DaemonSets确保pod的一个副本始终存在于集群的所有节点中,常用于MonitoringSolution、LogsViewer、Kube-porxy、Weave-net(networking)。daemon-set-definition.yamlkind......
  • STA Setup/Hold time 速查手册
    STASetup/Holdtime速查手册时序路径时序路径起点模块的input寄存器的clk端时序路径终点模块的output寄存器的数据输入端D关键路径拥有最小松弛的时序路径......
  • k8s--DaemonSet(DS) 控制器
    介绍DaemonSet类型的控制器可以保证在集群中的每一台(或指定)节点上都运行一个副本。一般用于日志收集、节点监控等场景。也就是说,如果一个pod提供的功能是节点级别的(每......