随笔 - 502  文章 - 1 评论 - 6 阅读 - 37万
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

参考地址: https://tech.antfin.com/docs/2/98726

1: maven引入jar

复制代码
        <!-- Jedis -->
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>2.9.0</version>
        </dependency>
        
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
            <version>2.8.0</version>
        </dependency>
复制代码

 

2:测试代码

复制代码
package com.gwzx.gwzxyw.utils;

import org.apache.commons.pool2.impl.GenericObjectPoolConfig;

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

/**
 * 操作redis简易工具类
 * @author
 *
 */
public class JedisUtil {
    
    private static JedisPool jedispool = null;
    
    public static void main(String[] args) {
        try {
            //连接池通用的一些设置
            GenericObjectPoolConfig poolconf = new GenericObjectPoolConfig();
            //设置连接池的属性
            //设置连接池最多创建50个jedis连接
            poolconf.setMaxTotal(60);
            //设置池中最多保留10个空闲的jedis连接
            poolconf.setMaxIdle(10);
            //设置池中最小保留5个空闲的jedis连接
            poolconf.setMinIdle(5);
            // 当资源池连接用尽后,调用者的最大等待时间(单位为毫秒)。默认值为-1,表示永不超时
            poolconf.setMaxWaitMillis(1000L * 2);
            //当连接用完时,是否阻塞客户端直到超时。false代表连接耗尽,直接给客户端抛异常
            poolconf.setBlockWhenExhausted(true);
            //从池中借一个连接时,先测试一下连接是否正常
            poolconf.setTestOnBorrow(true);
            //return 一个jedis实例给pool时,是否检查连接可用性(ping())
            //poolconf.setTestOnReturn(true);
            
            // 空闲检测
            // 如果为true,表示用一个专门的线程对空闲的连接进行有效性的检测扫描,如果有效性检测失败,即表示无效连接,会从资源池中移除。
            poolconf.setTestWhileIdle(true);
            // 表示一个Jedis连接至少停留在空闲状态的最短时间,然后才能被空闲连接扫描线程进行有效性检测,默认值为60000毫秒,即60秒。
            poolconf.setMinEvictableIdleTimeMillis(1000L * 60);
            // 表示两次空闲连接扫描的活动之间,要睡眠的毫秒数,默认为30000毫秒,也就是30秒钟。
            poolconf.setTimeBetweenEvictionRunsMillis(1000L * 30);
            // 表示空闲检测线程每次最多扫描的Jedis连接数,默认值为-1,表示扫描全部的空闲连接。
            poolconf.setNumTestsPerEvictionRun(-1);
            
            // public JedisPool(final GenericObjectPoolConfig poolConfig, final String host, int port, int timeout, final String password, final int database) 
            jedispool = new JedisPool(poolconf, "127.0.0.1", 6379, 2000, null, 0);

            //从池中获取一个连接
            Jedis jedis = jedispool.getResource();
            //使用
            System.out.println(jedis.ping());    //PONG
            String t = jedis.setex("receipt:aa", 30, "老郭laoguo..");
            System.out.println("t:" + t); //OK
            
            String value = jedis.get("receipt:aa");
            System.out.println("value:" + value);
            //将连接放回连接池
            jedis.close();
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("启动失败");
        }
    }

    
}
复制代码

 

posted on   1161588342  阅读(95)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
历史上的今天:
2020-06-30 Mysql 提示拷贝效率
2018-06-30 Spring MVC annotation-driven
2018-06-30 Spring MVC 自定义类型转换器
2018-06-30 Spring MVC 数据绑定流程
2018-06-30 Spring MVC 重定向
2018-06-30 Spring MVC 自定义视图
2018-06-30 Spring MVC 视图及视图解析器
点击右上角即可分享
微信分享提示