例如,假设我有以下代码:
return (long) redisTemplate.execute(new RedisCallback() {
@Override
public Object doInRedis(RedisConnection connection) throws DataAccessException {
String redisKey = RedisKeyUtil.getDAUKey(df.format(start), df.format(end));
connection.bitOp(RedisStringCommands.BitOperation.OR,
redisKey.getBytes(), keyList.toArray(new byte[0][0]));
return connection.bitCount(redisKey.getBytes());
}
});这个doInredis方法会在redis集群中执行而不是在我的程序中执行吗?
发布于 2020-12-03 21:05:18
不是的。RedisTemplate只是一个Springboot助手类,它简化了Redis数据访问代码,并且它仍然在线程中本地执行。
如果您的使用场景都与Redis的基本命令相关,您可以使用Lua (示例代码here)。但是,在列表操作中没有前缀过滤,所以您也可以尝试使用CompletableFuture,这样您的数据处理就不会阻塞其他操作。
发布于 2020-12-03 02:57:34
您的Java代码不能在Redis中运行。Redis甚至不知道JVM,所以它根本不能做到这一点。
https://stackoverflow.com/questions/65114022
复制相似问题