Redisson 为每个请求获取新连接

问题描述

我目前正在为 redis 测试 reddison 客户端。对于一个简单的 RMap 集,我得到了 10 毫秒的时间。和jedis相比,jedis只需要2ms就可以完成设置和获取。我的 reddison 测试代码如下

public static void main(String[] args) {
Config config = new Config();
config.useSentinelServers().setCheckSentinelsList(false).setMasterName("mymaster")
        .addSentinelAddress("redis://localhost:26379").setPassword("zzz");

RedissonClient redisson = Redisson.create(config);
RMap<String,String> map = redisson.getMap("myMap");
while (true) {
    System.out.println("ENTER");
    Scanner in = new Scanner(system.in);
    String s = in.nextLine();
    try {
        LocalDateTime start = LocalDateTime.Now();
        map.put("test",s);
        System.out.println("OUTPUT:::" + map.get("test"));
        System.out.println(Duration.between(start,LocalDateTime.Now()).toMillis());
    } catch (Exception e) {
        e.printstacktrace();
    }
}

}

在检查调试日志后,我发现 reddison 每次在执行 put 或 get 之前都会获取一个连接(LOG:: 获取命令的连接)。有没有办法让 redisson 客户端对所有请求使用相同的连接并避免这种成本?

解决方法

Redisson 使用连接池。 从不为每个操作创建新连接。对数据的第一次操作可能需要默认编解码器来进行初始化。自 3.16.1 版本起增加了默认数据编解码器预热过程。