您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

浅析Python中怎么用Redis

2024/2/26 19:01:23发布16次查看
python中怎么用redis?下面本篇文章给大家介绍一下python使用redis的方法,希望对大家有所帮助!
前面我们都是使用 redis 客户端对 redis 进行使用的,但是实际工作中,我们大多数情况下都是通过代码来使用 redis 的,由于小编对 python 比较熟悉,所以我们今天就一起来学习下如何使用 python 来操作 redis。【相关推荐:redis视频教程】
环境准备redis 首先需要安装好。python 安装好(建议使用 python3)。redis 的 python 库安装好(pip install redis)。开始实践小试牛刀例:我们计划通过 python 连接到 redis。然后写入一个 kv,最后将查询到的 v 打印出来。
直接连接#!/usr/bin/python3import redis # 导入redis模块r = redis.redis(host='localhost', port=6379, password="pwd@321", decode_responses=true) # host是redis主机,password为认证密码,redis默认端口是6379r.set('name', 'phyger-from-python-redis') # key是"name" value是"phyger-from-python-redis" 将键值对存入redis缓存print(r['name']) # 第一种:取出键name对应的值print(r.get('name')) # 第二种:取出键name对应的值print(type(r.get('name')))
其中的 get 为连接池最后一个执行的命令。
连接池通常情况下,需要连接 redis 时,会创建一个连接,基于这个连接进行 redis 操作,操作完成后去释放。正常情况下,这是没有问题的,但是并发量较高的情况下,频繁的连接创建和释放对性能会有较高的影响,于是连接池发挥作用。
连接池的原理:预先创建多个连接,当进行 redis 操作时,直接获取已经创建好的连接进行操作。完成后,不会释放这个连接,而是让其返回连接池,用于后续 redis 操作!这样避免连续创建和释放,从而提高了性能!
#!/usr/bin/python3import redis,time # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库pool = redis.connectionpool(host='localhost', port=6379, password="pwd@321", decode_responses=true) # host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379r = redis.redis(connection_pool=pool)r.set('name', 'phyger-from-python-redis')print(r['name'])print(r.get('name')) # 取出键name对应的值print(type(r.get('name')))
你会发现,在实际使用中直连和使用连接池的效果是一样的,只是在高并发的时候会有明显的区别。
基操实践对于众多的 redis 命令,我们在此以 set 命令为例进行展示。
格式: set(name, value, ex=none, px=none, nx=false, xx=false)
在 redis-py 中 set 命令的参数:
参数名释义
ex <int>过期时间(m)
px <int>过期时间(ms)
nx <bool>如果为真,则只有 name 不存在时,当前 set 操作才执行
xx <bool>如果为真,则只有 name 存在时,当前 set 操作才执行
ex我们计划创建一个 kv 并且设置其 ex 为 3,期待 3 秒后此 k 的 v 会变为 none。
#!/usr/bin/python3import redis,time # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库pool = redis.connectionpool(host='localhost', port=6379, password="pwd@321", decode_responses=true) # host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379r = redis.redis(connection_pool=pool)r.set('name', 'phyger-from-python-redis',ex=3)print(r['name']) # 应当有vtime.sleep(3)print(r.get('name')) # 应当无vprint(type(r.get('name')))
nx由于 px 的单位太短,我们就不做演示,效果和 ex 相同。
我们计划去重复 set 前面已经 set 过的 name,不出意外的话,在 nx 为真时,我们将会 set 失败。但是人如果 set 不存在的 name1,则会成功。
#!/usr/bin/python3import redis,time # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库pool = redis.connectionpool(host='localhost', port=6379, password="pwd@321", decode_responses=true) # host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379r = redis.redis(connection_pool=pool)r.set('name', 'phyger-0',nx=3) # set失败print(r['name']) # 应当不生效r.set('name1', 'phyger-1',nx=3) # set成功print(r.get('name1')) # 应当生效print(type(r.get('name')))
如上,你会发现 name 的 set 未生效,因为 name 已经存在于数据库中。而 name1 的 set 已经生效,因为 name1 是之前在数据库中不存在的。
xx我们计划去重复 set 前面已经 set 过的 name,不出意外的话,在 nx 为真时,我们将会 set 成功。但是人如果 set 不存在的 name2,则会失败。
#!/usr/bin/python3import redis,time # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库pool = redis.connectionpool(host='localhost', port=6379, password="pwd@321", decode_responses=true) # host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379r = redis.redis(connection_pool=pool)r.set('name', 'phyger-0',xx=3) # set失败print(r['name']) # 应当变了r.set('name2', 'phyger-1',xx=3) # set成功print(r.get('name2')) # 应当没有set成功print(type(r.get('name')))
以上,就是今天全部的内容,更多信息建议参考 redis 官方文档。
更多编程相关知识,请访问:编程视频!!
以上就是浅析python中怎么用redis的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product