当前位置: 首页 > 面试题库 >

Spring Data Redis:Redis管道始终返回null

谷梁博易
2023-03-14
问题内容

我想只使用指定的字段检索多个hashmap值。所以我选择了Redis管道。

在测试下面的代码时,我redisResponse1总是看到null,它redisResponse2具有价值。

    getRedisTemplate().executePipelined(new RedisCallback<Object>() { 
        @Override
        public Object doInRedis(RedisConnection connection) throws DataAccessException {
                List<byte[]> redisResponse1 = connection.hMGet(key.getBytes(), params);
                List<byte[]> redisResponse2 = getRedisTemplate().getConnectionFactory().getConnection().hMGet(key.getBytes(), specificParams);
                return null;
        }
    });

当我查看代码并发现下面的内容时,

a)redisResponse2不使用管道选项执行

b)redisResponse1用管道执行(isPipelined()== true),但始终返回null。

public List<byte[]> hMGet(byte[] key, byte[]... fields) {
    try {
        if (isPipelined()) {
            pipeline(new JedisResult(pipeline.hmget(key, fields)));
            return null;
        }
        if (isQueueing()) {
            transaction(new JedisResult(transaction.hmget(key, fields)));
            return null;
        }
        return jedis.hmget(key, fields);
    } catch (Exception ex) {
        throw convertJedisAccessException(ex);
    }
}

所以问题是

1)如何通过管道选项实现用例?

2)getRedisTemplate().getConnectionFactory().getConnection()在此RedisCallback中访问有什么影响?

3)整个管道概念如何运作?就像动态的Lua吗?该Java代码在哪里转换为Lua脚本并作为脚本发送到Redis,在Redis中执行然后返回?在此回调中感到惊讶;代码也正在访问/更新外部类变量,那么所有这些变量将如何处理?所有这些外部类变量也会在lua中发送给redis吗?

4)我看到许多关于doInRedisAPI返回的示例null;为什么这样?如何从中返回/获取有效的对象?


问题答案:

Spring Data Redis 参考文档中提供了大多数问题。

在深入研究流水线之前,来自一个哈希的单个多重获取不需要流水线,因为它只是一个命令。管道传输不会提高Redis交互的性能/稳定性/…。

流水线被安排为回调,旨在发出多个命令而无需立即等待结果–将其视为一批,您可以在以后获得所有结果。因为流水线在最后就同步了响应,所以当流水线会话同步executePipelined(…)终止时,您不会在回调内收到结果值,而是在最后。

您的代码应如下所示:

List<Object> results = getRedisTemplate().executePipelined(new RedisCallback<Object>() {

    @Override
    public Object doInRedis(RedisConnection connection) {

            connection.hMGet(key.getBytes(), params);

            return null;
    }
});

List<Object> hmget = (List<Object>) results.get(0);

您只需要使用收到的作为回调参数的连接,因为该连接已进入流水线模式。从回调外部获取连接(如template.getConnectionFactory().getConnection())将打开一个新连接,并在等待响应的情况下执行Redis命令-
没有流水线应用于任何外部获得的连接。

您也可以使用的方法来RedisTemplate代替普通连接。executePipelined(…)将回调中使用的连接绑定到当前线程,并在调用模板API方法时重用该绑定的连接。

关于您的Lua问题:代码/方法调用不会移调到Lua。



 类似资料:
  • 问题内容: 我以前使用过媒体播放器,但从未遇到过此问题。每当我尝试使用MediaPlayer.create()时,该方法都会使我为null,并且无法播放声音。有什么我想念的吗? 我的sound.mp3在我的原始文件夹中,通过将声音拖到eclipse中的文件夹中,我将其放置在其中。请帮忙,因为我以前玩过声音,所以这真的困扰我:( 问题答案: 如果create() API由于某种原因失败,则返回nul

  • 问题内容: 尽管是有效的类,但以下代码会打印。 文档说方法返回 由 aClassName 命名的类对象,或者如果当前没有加载该名称的类。如果 aClassName 为,则返回。 我也试图获得当前的viewcontroller已加载但仍然得到 可能是什么问题? 更新: 即使尝试这样做,我仍然可以 问题答案: 该函数 确实 适用于(纯和Objective-C派生的)swift类,但是仅当您使用全限定名

  • 问题内容: 我觉得有点愚蠢,但它不起作用: 我有如果给定的用户是unicode。如果字符串中包含或,我想打印成功,但是我总是得到的结果。 问题答案: 隐式锚定到字符串的开头。如果要在字符串中搜索可以在字符串中任何位置的子字符串,则需要使用: 输出: 另外,Python Regexes不需要在开头和结尾都有一个。 最后,我添加到该行的末尾,因为我认为这就是您想要的。否则,您会得到类似的信息,但并不太

  • 我的安全配置似乎不正确。无论我在使用hasRole时做什么,我的endpoint总是返回403。 此外,除非我在这两个和。很明显,我遗漏了一些东西。 基本上,我希望所有内容都需要身份验证,但只有当用户是某些组的成员时(现在只需要admin),少数endpoint才可以访问。 我的安全配置如下。旁边的一切都有效。 我的AuthenticationConfiguration如下 我的Authoriza

  • 我正在尝试使用NSKeyDarchiver在应用程序关闭和运行周期之间存储数据。我试图存储的根对象是一个NSMutableArray,但在这个对象中有基础对象和自定义对象的集合(所有这些都符合NSCoding)。 文件保存代码如下 该文件保存fine并且不会抛出异常。再次启动应用程序时,使用以下代码恢复该文件。 在这一点上,sessionData总是为零,而pData是几千字节长的,因此我知道问题

  • 我有以下异常处理程序: 此代码应该包装异常并返回具有正确状态代码的ResponseEntity。