【发布时间】:2021-09-27 00:42:29
【问题描述】:
我目前正在为 redis 测试 reddison 客户端。对于一个简单的 RMap 集,我得到了 10 毫秒的时间。与 jedis 相比,jedis 只需 2 毫秒即可完成设置和获取。我的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:: acquire connection for command)。有没有办法让 redisson 客户端对所有请求使用相同的连接并避免这种成本?
【问题讨论】: