Redis合集 第二章 redis客户端 第一节 jedis

jedis

线程不安全 所以每个线程需要一个独立的链接 为了保证线程安全 所以需要连接池

创建jedis链接池

java 复制代码
public class JedisConnectionFactory
{
    public static final JedisPool jedispool;

    static{
        //配置连接池
        JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
        jedisPoolConfig.setMaxTotal(8);
        jedisPoolConfig.setMaxIdle(8);
        //最小空闲链接
        jedisPoolConfig.setMinIdle(0);
        jedisPoolConfig.setMaxWait(Duration.ofNanos(100000));

        //创建连接池对象
        jedispool = new JedisPool(jedisPoolConfig, "xxxxxx",
                6379, 1000, "XXXXXX");
    }

    public static Jedis getJedis(){
        return jedispool.getResource();
    }

}

说明:

JedisPoolConfig() 创建一个配置对象,使用无参构造方法就可以了

void setMaxTotal() 设置连接池最大的连接数

void setMaxWait() 刚开始没连上最多等待的时间

void setMaxIdle() 设置最大空闲链接数 也就是在线程池中最多有多少个空闲的链接

void setMinIdle() 设置最小空闲连接数

使用jedis (jedis的api就是redis命令)

java 复制代码
public class jedisTest
{
    private Jedis jedis;

    @BeforeEach
    void setUp(){
        jedis = JedisConnectionFactory.getJedis();
    }

    @Test
    void testString(){
        String set = jedis.set("name", "虎哥");
        System.out.println("set = " + set);
        String name = jedis.get("name");
        System.out.println("name = " + name);
    }

    @Test
    void testHash(){
        jedis.hset("user:1","name", "name1");
        jedis.hset("user:1","age", "1");
        Map<String, String> stringStringMap = jedis.hgetAll("user:1");
        stringStringMap.forEach((k,v) -> System.out.println("v = " + v));
    }

    @AfterEach
    void tearDown(){
        if (jedis != null){
            jedis.close();
        }
    }

}
相关推荐
plainGeekDev10 分钟前
MVC 写法 → MVVM
android·java·kotlin
SL_staff39 分钟前
3周搭完MES系统:JVS低代码+JVS-IoT物联网的实战记录
java·前端·低代码
MacroZheng1 小时前
斩获20w star!Claude Code最强插件,AI编程必备!
java·人工智能·后端
唐青枫2 小时前
Java Spring WebFlux 实战指南:用 Mono、Flux 和 WebClient 写响应式接口
java·spring
小bo波15 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking16 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
张不才19 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd11120 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
ClouGence1 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
plainGeekDev1 天前
单例模式 → object 声明
android·java·kotlin