广告
返回顶部
首页 > 资讯 > 后端开发 > Python >使用python怎么批量操作redis数据库
  • 741
分享到

使用python怎么批量操作redis数据库

2023-06-08 00:06:09 741人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

使用python怎么批量操作redis数据库?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。方法一:使用 pipeline  使用pipelining

使用python怎么批量操作redis数据库?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

方法一:使用 pipeline

  使用pipelining 发送命令时,Redis server必须部分请求放到队列中(使用内存)执行完毕后一次性发送结果,在 pipeline 使用期间,将“独占”链接,无法进行非“管道”类型的其他操作,直至 pipeline 关闭;如果 pipeline 的指令集很多很庞大,为了不影响其他操作(redis 最大时间lua-time-limit默认是5s),可以使用其他新建新链接操作。批量操作如下:

import redisr = redis.Redis(host='127.0.0.1', port=6379, passWord='1234567890')with r.pipeline() as ctx:  a = time.time()  ctx.hset('current', "time2", a)  ctx.hset('current', "time3", a)  res = ctx.execute()  print("result: ", res)

使用 pipe line 以乐观的形式执行事务操作

# -*- coding:utf-8 -*-import redisfrom redis import WatchErrorfrom concurrent.futures import ProcessPoolExecutorr = redis.Redis(host='127.0.0.1', port=6379)# 减库存函数, 循环直到减库存完成# 库存充足, 减库存成功, 返回True# 库存不足, 减库存失败, 返回Falsedef decr_stock():  # Python中redis事务是通过pipeline的封装实现的  with r.pipeline() as pipe:    while True:      try:        # watch库存键, multi后如果该key被其他客户端改变, 事务操作会抛出WatchError异常        pipe.watch('stock:count')        count = int(pipe.get('stock:count'))        if count > 0: # 有库存          # 事务开始          pipe.multi() # multi 判断 watch 监控的 key 是否被其他客户端改变          pipe.decr('stock:count')          # 把命令推送过去          # execute返回命令执行结果列表, 这里只有一个decr返回当前值          result = pipe.execute()[0]          print("result: ", result)          return True        else:          return False      except WatchError as e:        # 打印WatchError异常, 观察被watch锁住的情况        print(e.args)      finally:        pipe.unwatch()def worker():  while True:    # 没有库存就退出    if not decr_stock():      break# 实验开始# 设置库存为100r.set("stock:count", 100)# 多进程模拟多个客户端提交with ProcessPoolExecutor(max_workers=2) as pool:  for _ in range(10):    pool.submit(worker)

方法二:使用 reGISter_script 

分布执行,发送脚本到redis服务器,获取一个本次连接的一个调用句柄,根据此句柄可以无数次执行不同参数调用

import redisimport time  r = redis.Redis(host='127.0.0.1', port=31320, password='12345678')    lua = """  local key = KEYS[1]  local field = ARGV[1]  local timestamp_new = ARGV[2]    -- get timestamp of the key in redis  local timestamp_old = redis.call('hget', key, field)  -- if timestamp_old == nil, it means the key is not exist  if timestamp_old == nil or timestamp_old == false or timestamp_new > timestamp_old then    redis.call('hset', key, field .. 1, timestamp_new)    -- timestamp_new > timestamp_old    return redis.pcall('hset', key, field, timestamp_new)  end    """  cmd = r.register_script(lua)  cur_time = time.time()  cmd(keys=['current'], args=["time", cur_time])

register_script 调用 lua 来实现,需要注意 redis.call(method, key, field) 的返回值(nil,false,1),此处没有键值返回的是false。如果中间有错误,所有的语句不时不生效。

方法三:使用 script_load 和 evalsha

简而言之,通过 script_load 发送给redis服务器,使加载 lua 脚本,并常驻内存,返回标志,通过 evalsha 按标志进行执行,此连接脱离本次redis 客户端。

import redisimport time  r = redis.Redis(host='127.0.0.1', port=31320, password='12345678')    lua = """  local key = KEYS[1]  local field = ARGV[1]  local timestamp_new = ARGV[2]    -- get timestamp of the key in redis  local timestamp_old = redis.call('hget', key, field)  -- if timestamp_old == nil, it means the key is not exist  if timestamp_old == nil or timestamp_old == false or timestamp_new > timestamp_old then    redis.call('hset', key, field .. 1, timestamp_new)    -- timestamp_new > timestamp_old    return redis.pcall('hset', key, field, timestamp_new)  end    """  sha = r.script_load(lua)  print(r.evalsha(sha, 1, 'current', 'time', time.time()))

Redis 管理Lua脚本:(Python下为 script_... )

  • script load

此命令用于将Lua脚本加载到Redis内存中

  • script exists

scripts exists sha1 [sha1 …]  
此命令用于判断sha1是否已经加载到Redis内存中

  • script flush 

此命令用于清除Redis内存已经加载的所有Lua脚本,在执行script flush后,所有 sha 不复存在。

  • script kill 

此命令用于杀掉正在执行的Lua脚本。

方法四:eval

使用方法与方法三类似,但是eval是一次性请求,每次请求,必须携带 lua 脚本

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网Python频道,感谢您对编程网的支持。

--结束END--

本文标题: 使用python怎么批量操作redis数据库

本文链接: https://www.lsjlt.com/news/250581.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 使用python怎么批量操作redis数据库
    使用python怎么批量操作redis数据库?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。方法一:使用 pipeline  使用pipelining ...
    99+
    2023-06-08
  • 怎么使用Python操作Redis数据库
    本篇内容主要讲解“怎么使用Python操作Redis数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用Python操作Redis数据库”吧!介绍Redis是一个开源的基于内存也可持久化...
    99+
    2023-07-02
  • python怎么操作redis数据库
    今天小编给大家分享一下python怎么操作redis数据库的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、安装redis ...
    99+
    2023-06-30
  • SpringBoot Redis批量存取数据的操作
    SpringBoot Redis批量存取数据 springboot中的redisTemplate封装了redis批处理数据的接口,我们使用redisTemplate可以直接进行批量数...
    99+
    2022-11-12
  • 怎么使用Redis批量生成数据
    这篇文章主要介绍“怎么使用Redis批量生成数据”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用Redis批量生成数据”文章能帮助大家解决问题。Redis自带Debug方法redis提供的de...
    99+
    2023-06-30
  • Python操作redis数据库
    前言:这两天的事情不多,为了避免之前学习的一点点Python知识遗忘,我在Github上找了一些小项目跟着实践。之前的工作有写过相关的Python处理redis处理数据的脚本,但之前没有养成记录积累的习惯,所以~~~~(遗忘了),所以趁此...
    99+
    2023-01-31
    操作 数据库 Python
  • python数据怎么批量写入数据库
    在Python中,可以使用循环和SQL语句将数据批量写入数据库。以下是一个示例,展示了如何使用Python的`sqlite3`模块将...
    99+
    2023-10-11
    python 数据库
  • PHP中使用Redis实现批量操作
    Redis是一款非常流行的高性能的内存数据库,在PHP开发中,使用Redis可以实现诸如缓存、锁等应用场景。本文将介绍如何使用Redis实现批量操作。一、Redis批量操作概述Redis提供了一系列的批量命令,可以在一次请求中同时处理多个键...
    99+
    2023-05-16
    PHP redis 批量操作
  • 怎么通过shell脚本批量操作mysql数据库
    这篇文章主要讲解了“怎么通过shell脚本批量操作mysql数据库”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么通过shell脚本批量操作mysql数据库”吧!创建建表语句  =====...
    99+
    2023-06-05
  • IDEA版怎么使用Java操作Redis数据库
    本篇内容主要讲解“IDEA版怎么使用Java操作Redis数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“IDEA版怎么使用Java操作Redis数据库”吧!首先 下载 jedis.jar包...
    99+
    2023-06-20
  • SpringBoot Redis怎么批量存取数据
    这篇文章主要介绍“SpringBoot Redis怎么批量存取数据”,在日常操作中,相信很多人在SpringBoot Redis怎么批量存取数据问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SpringBoo...
    99+
    2023-06-20
  • 使用PHP操作Redis数据库
    Redis是一款基于内存的高性能键值对数据库,可以被用于缓存、队列等多种场景。而PHP是一种开发语言,可以用于Web开发、后端服务等多种场景。如果我们能够将PHP和Redis结合使用,可以达到更优秀的性能和效果。本文将介绍如何使用PHP操作...
    99+
    2023-05-16
    PHP redis 数据库操作
  • python怎么批量统计Oracle数据库的空间使用量
    这篇文章主要介绍“python怎么批量统计Oracle数据库的空间使用量”,在日常操作中,相信很多人在python怎么批量统计Oracle数据库的空间使用量问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”pyt...
    99+
    2023-06-04
  • Apache POI操作批量导入MySQL数据库
    目录1、POI操作入门案例1.1、从Excel文件读取数据11.2、从Excel文件读取数据21.3、向Excel文件写入数据2、使用POI批量导入数据到mysql数据库2.1、创建导入数据的Excel模板文件2.2、批...
    99+
    2022-06-20
    Apache POI批量导入MySQL Apache POI导入MySQL
  • 数据库批量操作锁定和释放库存
    type类型:1锁定,2释放 实现思路:利用【case when and then end】来判断锁定和释放是否超过库存限制,若是超过则SQL不成立,执行后会报错,表示锁定或释放库存失败 update stock_re...
    99+
    2023-09-01
    mysql
  • 怎么在python中使用faker库批量生成假数据
    这篇文章将为大家详细讲解有关怎么在python中使用faker库批量生成假数据,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。faker使用方法基本使用faker使用起来非常简单,我们看一下就...
    99+
    2023-06-08
  • 使用Python怎么操作MySQL数据库
    本篇文章给大家分享的是有关使用Python怎么操作MySQL数据库,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。MySQL 建表建表的时候,遇到一些坑,没有解决,如修改 MyS...
    99+
    2023-06-14
  • spring使用RedisTemplate操作Redis数据库
    一.什么是Redis Redis是一个非关系型数据库,具有很高的存取性能,一般用作缓存数据库,减少正常存储数据库的压力。 Redis可以存储键与5种不同数据结构类型之间的映射,这5种...
    99+
    2022-11-11
  • python 实现 redis 数据库的操作
    目录一、安装二、连接三、string基本命令四、hash基本命令五、list基本命令六、set基本命令七、zset基本命令八、其他通用命令九、管道命令一、安装 redis 是一个 K...
    99+
    2022-11-10
  • Springboot下使用Redis管道(pipeline)进行批量操作
    目录前言管道(pipeline)的优势1.网络传输(RTT)开销少2.提高redis每秒可以执行操作的数量分别使用RedisCallback、SessionCallback进行Red...
    99+
    2023-05-20
    Springboot Redis管道批量操作 Springboot Redis管道
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作