python redis批量执行插入

​​​​​​​import random
from RedisClient import RedisClient
import time,datetime
redis=RedisClient('127.0.0.1',6379)
redis_three=redis.conn(0)
redis_three.set('RudderAngleControl', str(random.randint(0,35)))
redis_three.set('RudderAngle', str(random.randint(0,35)))
…… *1000

如上代码当数据超过100条之后效率会明显的慢下来。

执行上面的python代码命令时,执行1000次get key,这时你要向redis请求1000次+获取响应1000次。如果能一次性将1000个请求提交给redis server,执行完成之后批量的获取相应,只需要向redis请求1次,然后批量执行完命令,一次性结果,性能会有成几何倍的提升。

下面是修改后的python代码:

import random
from RedisClient import RedisClient
import time,datetime

pr=datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S.%f')
print("开始时间--"+pr)
redis=RedisClient('127.0.0.1',6379)
r=redis.conn(0)
with r.pipeline(transaction=False) as redis_three:
    redis_three.set('H0XXXXX', str(random.uniform(0,99)),ttl)
    redis_three.set('H0XXXXX', str(random.uniform(0,99)),ttl)
    redis_three.set('H0XXXXX', str(random.uniform(0,99)),ttl)
    redis_three.set('H0XXXXX', str(random.uniform(0,99)),ttl)
    ……*1000
    redis_three.execute()#上面的1000条数据在这里统一执行
printa=datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S.%f')
print("结束时间--"+printa)

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值