Redis数据检索

时间:2016-09-15 18:19:08

标签: java caching redis

我在redis缓存中有一个地图,结构如下:

缓存条目:Map<String, Map<String, String>>

内部地图可以有多达25000个元素/桶。 有没有办法在redis中根据键(redis键,外部映射的键和内部映射的键)从内部映射中检索特定值,而不必在我的Java方法中获取访问此redis缓存的整个redis条目?< / p>

目前,如果我必须从内部地图中删除特定的密钥,请按以下方式执行:

Map<String, Map<String, String>> mapFromRedis = redis.get("myRediscacheKey");
Map<String, String> innerMap = new HashMap<>();
if (!mapFromRedis.isEmpty()) {
    innerMap = mapFromRedis.get("key");
}
if (innerMap.containsKey("keyToBeDeleted")) {
    innerMap.remove("keyToBeDeleted");
    mapFromRedis.put("key", innerMap);
}
redis.set("myRediscacheKey", mapFromRedis);

2 个答案:

答案 0 :(得分:0)

您的数据结构具有3级映射: Redis密钥外部映射密钥内部映射密钥。在您的示例中,我们可以获得以下映射:myRediscacheKey -> key -> keyToBeDeleted -> value

但是,Redis最多只能有2级映射,即HASH。为了实现您的目标,您必须压缩 3级映射到2级映射,甚至是1级映射。

  

压缩到2级映射

您可以将Redis键与外部地图键组合为HASH的键,并将内部地图键作为HASH的字段。通过这种方式,我们可以得到如下的2级映射:myRediscacheKey:key -> keyToBeDeleted -> value

// set inner map key
hset myRediscacheKey:key keyToBeDeleted value
// remove inner map key
hdel myRediscacheKey:key keyToBeDeleted
  

压缩到1级映射

您还可以将3个键合并为一个键:myRediscacheKey:key:keyToBeDeleted -> value

// set inner map key
set myRediscacheKey:key:keyToBeDeleted value
// remove inner map key
del myRediscacheKey:key:keyToBeDeleted

答案 1 :(得分:0)

您可以使用Redisson轻松完成此操作。它允许通过Redisson处理的特殊参考对象将Redis对象引用到另一个Redis对象。这是代码示例:

RMap<String, RMap<String, String>> mapFromRedis = redisson.getMap("myRediscacheKey");

// Redisson loads only small reference object 
// to another Redis map and NOT entire map
Map<String, String> innerMap = mapFromRedis.get("key");

if (innerMap.remove("keyToBeDeleted") != null) {
   // key has been deleted
}
// or with faster approach
if (innerMap.fastRemove("keyToBeDeleted") == 1) {
   // key has been deleted
}

就是这样!您不需要对每个内部地图更改执行大量更新。在引擎盖下,它仅使用Redis上的2个操作:gethdel

RMap扩展了标准的Java MapConcurrentMap接口。因此,您不需要处理键/连接/序列化。这一切都是由Redisson完成的。