问题描述
我目前正在为 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 版本起增加了默认数据编解码器预热过程。