繁体   English   中英

如何将数据从数据库加载到Redis缓存中?

[英]how to load data into redis cache from database?

我们计划在应用程序中使用Redis缓存,我们的要求是首先需要在实际应用程序启动之前将大约6个月的数据加载到Redis缓存中,我认为如果我们一次循环执行一个命令来插入键值,到Redis中会花费太多时间,是他们可以从数据库中检索数据并一口气将所有数据插入Redis的方法吗?

有人可以建议吗?

Redis提供了对流水线的支持,该流水线涉及到向服务器发送多个命令,而无需等待答复,然后一步就可以读取答复。 当您需要连续发送多个命令(例如将多个元素添加到同一List)时,流水线可以提高性能。

Spring Data Redis提供了几种RedisTemplate方法来执行管道中的命令。

一个例子:

//pop a specified number of items from a queue
List<Object> results = stringRedisTemplate.executePipelined(
  new RedisCallback<Object>() {
    public Object doInRedis(RedisConnection connection) throws DataAccessException {
      StringRedisConnection stringRedisConn = (StringRedisConnection)connection;
      for(int i=0; i< batchSize; i++) {
        stringRedisConn.rPop("myqueue");
      }
    return null;
  }
});

您可以点击此链接

或者,您也可以使用Redis Mass插入工具。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM