RedisCacheManager不更新keyspace_misses

时间:2018-04-25 22:53:09

标签: java spring spring-boot redis spring-data-redis

我正在使用CacheManager的spring-boot spring-data-redis 1.8.9.RELEASE RedisCacheManager实现进行缓存。我想要查看的一个指标是缓存命中/未命中率。为此,我将通过redis服务器提取keyspace_hits and keyspace_misses,这也可以通过redis_cli查看INFO STATS。问题是RedisCacheManager从不注册缓存未命中,即即使存在缓存“未命中”,keyspace_misses也不会递增。

调试代码,我看到spring-data-redis在检索之前实际检查redis中的密钥EXISTS。我看到了这种方法的意义,但是当对redis服务器执行EXISTS时,它没有注册缓存未命中。

有没有办法使用RedisCacheManager并注册缓存未命中?我知道我可以使用其他redis对象来实现这一点,但我想知道是否可以使用标准的CacheManager实现来完成它?

修改

理想的解决方案不会增加大量开销,我无法编辑redis服务器的配置。

RedisCacheManager从缓存中检索元素时使用的代码。请注意Boolean exists

public RedisCacheElement get(final RedisCacheKey cacheKey) {
    Assert.notNull(cacheKey, "CacheKey must not be null!");
    Boolean exists = (Boolean)this.redisOperations.execute(new RedisCallback<Boolean>() {
        public Boolean doInRedis(RedisConnection connection) throws DataAccessException {
            return connection.exists(cacheKey.getKeyBytes());
        }
    });
    return !exists ? null : new RedisCacheElement(cacheKey, this.fromStoreValue(this.lookup(cacheKey)));
}

以上代码将通过MONITOR在缓存未命中时在redis上执行这些命令。再次注意,EXISTS按照代码执行:

Redis commands executed for a cache miss

执行上述命令后,即使存在缓存未命中,keyspace_misses也不会递增:

enter image description here

1 个答案:

答案 0 :(得分:1)

问题中提到的代码是Spring提供的RedisCache的一部分。

  1. 扩展并创建RedisCache类的自定义实现,以覆盖“ get”方法的行为以满足您的需要。
  2. 扩展RedisCacheManager以覆盖方法“ createRedisCache”,以使用在第一步中创建的自定义RedisCache而不是默认缓存。