不做大哥好多年 不做大哥好多年
首页
  • MySQL
  • Redis
  • Elasticsearch
  • Kafka
  • Etcd
  • MongoDB
  • TiDB
  • RabbitMQ
  • 01.GO基础
  • 02.面向对象
  • 03.并发编程
  • 04.常用库
  • 05.数据库操作
  • 06.Beego框架
  • 07.Beego商城
  • 08.GIN框架
  • 09.GIN论坛
  • 10.微服务
  • 01.Python基础
  • 02.Python模块
  • 03.Django
  • 04.Flask
  • 05.SYL
  • 06.Celery
  • 10.微服务
  • 01.Java基础
  • 02.面向对象
  • 03.Java进阶
  • 04.Web基础
  • 05.Spring框架
  • 100.微服务
  • Docker
  • K8S
  • 容器原理
  • Istio
  • 数据结构
  • 算法基础
  • 算法题分类
  • 前置知识
  • PyTorch
  • 01.Python
  • 02.GO
  • 03.Java
  • 04.业务问题
  • 05.关键技术
  • 06.项目常识
  • 10.计算机基础
  • Linux基础
  • Linux高级
  • Nginx
  • KeepAlive
  • ansible
  • zabbix
  • Shell
  • Linux内核

逍遥子

不做大哥好多年
首页
  • MySQL
  • Redis
  • Elasticsearch
  • Kafka
  • Etcd
  • MongoDB
  • TiDB
  • RabbitMQ
  • 01.GO基础
  • 02.面向对象
  • 03.并发编程
  • 04.常用库
  • 05.数据库操作
  • 06.Beego框架
  • 07.Beego商城
  • 08.GIN框架
  • 09.GIN论坛
  • 10.微服务
  • 01.Python基础
  • 02.Python模块
  • 03.Django
  • 04.Flask
  • 05.SYL
  • 06.Celery
  • 10.微服务
  • 01.Java基础
  • 02.面向对象
  • 03.Java进阶
  • 04.Web基础
  • 05.Spring框架
  • 100.微服务
  • Docker
  • K8S
  • 容器原理
  • Istio
  • 数据结构
  • 算法基础
  • 算法题分类
  • 前置知识
  • PyTorch
  • 01.Python
  • 02.GO
  • 03.Java
  • 04.业务问题
  • 05.关键技术
  • 06.项目常识
  • 10.计算机基础
  • Linux基础
  • Linux高级
  • Nginx
  • KeepAlive
  • ansible
  • zabbix
  • Shell
  • Linux内核
  • python基础

  • python模块

  • django

  • flask

  • SYL

    • day01

    • day02

    • day03

      • 00.作业
      • 01.图片验证码接口
      • 02.vue图片验证码
      • 03.短信验证接口
      • 04.redis的pipline使用
      • day04

      • day05

      • day06

      • day07

      • day08

      • day09

      • day10

      • day11

      • day12

    • Celery

    • 微服务

    • python
    • SYL
    • day03
    xiaonaiqiang
    2021-03-10
    目录

    04.redis的pipline使用

    # 1.pipeline原理

    redis基本语法:https://www.cnblogs.com/xiaonq/p/7919111.html

    redis四篇:https://www.cnblogs.com/xiaonq/category/1544586.html

    # 1.1 redis发送数据原理

    • Redis是建立在TCP协议基础上的CS架构,客户端client对redis server采取请求响应的方式交互。

    • 一般来说客户端从提交请求到得到服务器相应,需要传送两个tcp报文。

    • 设想这样的一个场景,你要批量的执行一系列redis命令,例如执行100次get key,这时你要向redis请求100次+获取响应100次。如果能一次性将100个请求提交给redis server,执行完成之后批量的获取相应,只需要向redis请求1次,然后批量执行完命令,一次性结果,性能是不是会好很多呢?

    # 1.2 未使用pipeline执行N条命令

    # 1.3 使用了pipeline执行N条命令

    # 2.pipeline性能代码展示

    In [1]: from django_redis import get_redis_connection       # 导入get_redis_connection模块
    In [2]: redis_client = get_redis_connection('default')      # 连接redis 0号库
        
    '''方法1:使用普通方法执行'''
    In [3]: for i in range(99999):
       ...:     redis_client.set(i,i)
    
    '''方法2:使用pipeline执行'''
    In [4]: p1 = redis_client.pipeline()           # 实例化一个pipeline对象             
    In [5]: for i in range(99999):
       ...:     p1.set(i,i)                        # 把要执行的命令打包到pipeline
    In [6]: p1.execute()
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    上次更新: 2024/3/13 15:35:10
    03.短信验证接口
    00.作业

    ← 03.短信验证接口 00.作业→

    最近更新
    01
    04.数组双指针排序_子数组
    03-25
    02
    08.动态规划
    03-25
    03
    06.回溯算法
    03-25
    更多文章>
    Theme by Vdoing | Copyright © 2019-2025 逍遥子 技术博客 京ICP备2021005373号
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式