我目前正在为redis测试reddison客户端。对于一个简单的RMap设置和get,我得到的时间是10ms。与绝地武士相比,绝地武士只需要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::acquired connection for command )之前都会获取一个连接。有没有办法让redisson客户端对所有请求使用相同的连接,并避免这种成本?
发布于 2021-07-25 01:14:56
Redisson使用连接池。从不为每个操作创建新的连接。对数据的第一次操作可能需要默认编解码器来进行初始化。从3.16.1版本开始,增加了默认数据编解码器预热过程。
https://stackoverflow.com/questions/68439008
复制相似问题