zoukankan      html  css  js  c++  java
  • Redis Pipelining

    官方文档:https://redis.io/topics/pipelining

    Springboot整合文档:https://docs.spring.io/spring-data/data-redis/docs/current/reference/html/#pipeline

    Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。这意味着通常情况下一个请求会遵循以下步骤:

      1)客户端向服务端发送一个查询请求,并监听Socket返回,通常是以阻塞模式,等待服务端响应。
      2)服务端处理命令,并将结果返回给客户端。

    Redis管道技术

      Redis提供了对pipelining(管道)的支持,pipelining涉及到向服务器发送多个命令,而无需等待响应,并最终一次性读取所有服务端的响应。当您需要连续发送多个命令时,例如将多个元素添加到同一列表中,pipelining可以提高性能

      Spring Data Redis提供了几种RedisTemplate方法来在pipelining中运行命令。如果您不关心pipelining操作的结果,则可以使用标准的execute方法,将pipelining参数传递为true。executePipelined 方法运行提供的 RedisCallback 或 SessionCallback 方法在管道中,并返回运行的结果。如:

         //pop a specified number of items from a queue,results包含所有pop的结果
            List<Object> results = redisTemplate.executePipelined(
                    new RedisCallback<Object>() {
                        @Override
                        public Object doInRedis(RedisConnection connection) throws DataAccessException {
                            StringRedisConnection stringRedisConn = (StringRedisConnection) connection;
                            // 批量执行的操作
                            for (int i = 0; i < batchSize; i++) {
                                stringRedisConn.rPop("myqueue");
                            }
                            // // 注意,RedisCallback返回的值必须为null,因为为了返回pipeline 命令的结果,该值被丢弃
                            return null;
                        }
                    });

    END.

  • 相关阅读:
    由PhysicalFileProvider构建的物理文件系统
    Net Core WebApi单元测试
    多个项目使用NET Core
    ReactNative
    定制样式插入到ueditor
    ES6的Class
    Redis存储Session
    二叉 查找树 排序树 搜索树
    SignalR实现实时日志监控
    KNN(k-nearest neighbor的缩写)又叫最近邻算法
  • 原文地址:https://www.cnblogs.com/yangyongjie/p/14354895.html
Copyright © 2011-2022 走看看