百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

python 模块Redis模块,连接Redis数据库

mhr18 2024-11-12 11:17 14 浏览 0 评论

Redis window安装教程
Redis超全语法大全

一、安装

官网:https://redis-py.readthedocs.io/en/stable/

pip install redis


二、连接数据库

  1. 同步连接
import redis

with redis.Redis(host='127.0.0.1',port=6379,decode_responses=True) as connect:
    connect.set('test','哈哈哈哈')
    print(connect.get('test'))
  1. 异步连接
import asyncio
import redis.asyncio as redis

async def run():
    async with redis.Redis(host='127.0.0.1',port=6379,decode_responses=True) as connect:
        await connect.set('test','我是异步')
        result = await connect.get('test')
        print(result)

asyncio.run(run())

三、连接数据库函数

  1. redis.Redis() 连接数据库
redis.Redis(
    host='localhost', #ip地址
    port=6379, #端口
    db=0, #数据库,默认 0
    password=None, #密码
    single_connection_client=False, #True,不使用连接池
    connection_pool=None, #连接池
    decode_responses=False, #True时,将返回结果decode,即将bytes类型改为默认utf-8
    socket_timeout=None, #响应的时间
    socket_connect_timeout=None, #建立连接超时时间
    retry_on_timeout=False, #True时, 命令超时后,将会重试一次, 重试成功则正常返回; 失败则抛出timeout异常;False时直接抛出异常
    retry_on_error=None, #重试错误列表
    max_connections=None, #最大连接数
)
  1. redis.asyncio.Redis() 异步连接数据库
import redis.asyncio as redis

redis.Redis(
    host='localhost', #ip地址
    port=6379, #端口
    db=0, #数据库,默认 0
    password=None, #密码
    single_connection_client=False, #True,不使用连接池
    connection_pool=None, #连接池
    decode_responses=False, #True时,将返回结果decode,即将bytes类型改为默认utf-8
    socket_timeout=None, #响应的时间
    socket_connect_timeout=None, #建立连接超时时间
    retry_on_timeout=False, #True时, 命令超时后,将会重试一次, 重试成功则正常返回; 失败则抛出timeout异常;False时直接抛出异常
    retry_on_error=None, #重试错误列表
    max_connections=None, #最大连接数
)

四、字符串操作,异步需要使用async await

  1. connect.set(name,value,ex=None, px=None, nx=False, xx=False) 设置值
'''
设置键和值(字符串类型)
ex - 过期时间(秒)
px - 过期时间(毫秒)
nx - 如果设置为True,则只有name不存在时,当前set操作才执行
xx - 如果设置为True,则只有name存在时,当前set操作才执行
'''

connect.set('test','哈哈哈哈')
  1. connect.setnx(name,value) 设置值,只有name不存在时,执行设置操作
  2. connect.setex(name, time, value)) 设置值,time过期时间(秒)
  3. connect.psetex(name, time_ms, value) 设置值,time_ms过期时间(毫秒)
  4. connect.mset({name1:value1,name2:value2,name3:value3,....}) 批量设置值
  5. connect.get(name) 获取值
  6. connect.mget(name1,name2,name3,.....) 批量获取值
  7. connect.getrange(name, start, end) 获取部分值
'''
name:键值名
start:开始index
end:结束index,不包含结束index的字符
'''

connect.set('test','哈哈哈哈')
print(connect.getrange('test', 0, 2))
  1. connect.getset(name,value) 设置新值,并获取旧值
  2. connect.setrange(name, offset, value) 从指定字符串索引offset开始,替换字符串
  3. connect.append(name,value) 在原有字符基础上追加字符
  4. connect.strlen(name) 返回name对应值的字节长度(一个汉字3个字节)
  5. connect.incr(name, amount=1) 自增 name 对应的值,当 name 不存在时,则创建 name=amount,否则,则自增
  6. connect.decr(name, amount=1) 自减 name 对应的值,当 name 不存在时,则创建 name=amount,否则,则自减
  7. connect.incrby(name, amount=1) 在原有数值基础上加上一定的数值,当 name 不存在时,则创建 name=amount
  8. connect.decrby(name, amount=1) 在原有数值基础上减去一定的数值,当 name 不存在时,则创建 name=amount
  9. connect.incrbyfloat( name, amount=1.0) 自增 name 对应的值,当 name 不存在时,则创建 name=amount,否则,则自增。
  10. connect.setbit(name, offset, value) 对 name 对应值的二进制表示的位进行操作
  11. connect.getbit(name,offset) 获取name对应的值的二进制表示中的某位的值 (0或1)
  12. connect.bitcount(key, start=None, end=None) 获取name对应的值的二进制表示中 1 的个数

五、列表操作,异步需要使用async await

  1. connect.lpush(name,values) 添加列表,从左边新增加
connect.lpush('test_list',1,2,3,4)
  1. connect.rpush(name,values) 添加列表,从右边新增加
  2. connect.lpushx(name,value) 向已有name的列表的左边添加元素,没有的话无法创建
  3. connect.rpushx(name,value) 向已有name的列表的右边添加元素,没有的话无法创建
  4. connect.linsert(name, where, refvalue, value) 在name对应的列表的某一个值前或后插入一个新值
'''
name - redis的name
where - BEFORE或AFTER
refvalue - 标杆值,即:在它前后插入数据
value - 要插入的数据
'''
connect.linsert('test_list','BEFORE','2','5')
  1. connect.lset(name, index, value) 指定索引位置重新赋值
  2. connect.lrem(name, value, num) 删除指定的value,num为负数时从后向前删除
  3. connect.lpop(name) 在name对应的列表的左侧获取第一个元素并在列表中移除,返回值则是第一个元素
  4. connect.rpop() 在name对应的列表的右侧获取第一个元素并在列表中移除,返回值则是第一个元素
  5. connect.blpop(keys, timeout) 将多个列表排列,按照从左到右去pop对应列表的元素
  6. connect.brpop(keys, timeout) 将多个列表排列,按照从右到左去移除各个列表内的元素
connect.blpop(['test_list','test_list1'], timeout=2)
  1. connect.rpoplpush(src, dst) 从一个列表取出最右边的元素,同时将其添加至另一个列表的最左边
'''
src - 要取数据的列表的 name
dst - 要添加数据的列表的 name
'''
connect.rpoplpush('test_list','test_list1')
  1. connect.brpoplpush(src, dst) 从一个列表的右侧移除一个元素并将其添加到另一个列表的左侧
'''
src - 取出并要移除元素的列表对应的name
dst - 要插入元素的列表对应的name
timeout - 当src对应的列表中没有数据时,阻塞等待其有数据的超时时间(秒),0 表示永远阻塞
'''
connect.brpoplpush('test_list','test_list1')
  1. connect.ltrim(name, start, end) 在name对应的列表中移除没有在start-end索引之间的值
  2. connect.llen(name) 获取name列表中值的数量
  3. connect.lindex(index) 取值(根据索引号取值)
  4. connect.lrange(name,start,end) 在name对应的列表中取出start-end索引之间的值,包含end

六、hash类型操作,异步需要使用async await

  1. connect.hset(name, key, value) 增加hash类型键值
  2. connect.hsetnx(name, key, value) 设置值,只有name不存在时,执行设置操作
  3. connect.hget(name,key) 获取对应的key值
  4. connect.hmset(name,{key1:value1,key2:value2,key3:value3,.....}) 批量添加值
  5. connect.hmget(name,[key1,key2,key3,...]) 批量获取值
  6. connect.hgetall(name) 取出所有的值
  7. connect.hkeys(name) 获取所有的key
  8. connect.hvals(name) 获取所有的value
  9. connect.hscan(name, cursor=0, match=None, count=None) 取值查看--分片读取
'''
name - redis的name
cursor - 游标(基于游标分批取获取数据)
match - 匹配指定key,默认None 表示所有的key
count - 每次分片最少获取个数,默认None表示采用Redis的默认分片个数
'''

connect.hscan('test')
  1. connect.hscan_iter(name, match=None, count=None) 利用yield封装hscan创建生成器,实现分批去redis中获取数据
'''
match - 匹配指定key,默认None 表示所有的key
count - 每次分片最少获取个数,默认None表示采用Redis的默认分片个数
'''
test = connect.hscan_iter('test')
for i in test:
    print(i)
  1. connect.hlen(name) 获取hash中键值对的个数
  2. connect.hstrlen(name,key) 获取指定key值的长度
  3. connect.hincrby(name, key, amount=1) 自增自减数(将key对应的value--整数 自增1或者2,或者别的整数 负数就是自减)
  4. connect.hincrbyfloat(name, key, amount=1.0) 自增自减浮点数(将key对应的value--浮点数 自增1.0或者2.0,或者别的浮点数 负数就是自减)
  5. connect.hdel(name,keys) 删除hash中键值对
connect.hdel('test','name') #删除一个
connect.hdel('test',['name','age']) #删除多个
  1. connect.hexists(name, key) 判断hash中key是否存在

七、set类型操作,异步需要使用async await

  1. connect.sadd(name,values) 对应的集合中添加元素
connect.sadd('test_set',1,2,3,4,5)
  1. connect.scard(name) 获取name集合中的个数
  2. connect.smembers(name) 获取name集合中的所有元素
  3. connect.sscan(name, cursor=0, match=None, count=None)
  4. connect.sscan_iter(name, match=None, count=None)
  5. connect.srem(name, values) 在name对应的集合中删除某些值
  6. connect.spop(name) 从集合移除一个成员,并将其返回,说明一下,集合是无序的,所有是随机删除的
  7. connect.srandmember(namem,num) 从集合随机取出num个元素
  8. connect.smove(src, dst, value) 将某个成员从一个集合中移动到另外一个集合
  9. connect.sismember(name, value) 检查value是否是name对应的集合的成员,结果为True和False
  10. connect.sdiff(keys) 获取多个集合的差集
connect.sdiff(['test_set','test_set1','test_set2'])
  1. connect.sdiffstore(dest, keys) 获取多个集合的差集,并存进一个新的集合
connect.sdiffstore('new_test_set',['test_set','test_set1','test_set2'])
  1. connect.sinter(keys) 获取多个集合的交集
  2. connect.sinterstore(dest, keys) 获取多个集合的差集,并存进一个新的集合
  3. connect.sunion(keys) 获取多个集合的并集
  4. connect.sunionstore(dest, keys) 获取多个集合的并集,并存进一个新的集合

八、有序集合类型,异步需要使用async await

  1. connect.zadd(name,mapping,nx= False,xx= False,ch= False,incr= False,gt= False,lt= False) 对应的集合中添加元素
'''
name - redis的name
mapping - 添加到集合的键值对
nx - 强制ZADD只创建新元素而不更新已经存在的元素的分数。
xx - 强制ZADD只更新已经存在的元素的分数存在。不会添加新元素。
ch - 将返回值修改为已更改的元素数。更改的元素包括添加的新元素和元素谁的分数变了。
incr - 修改ZADD的行为像ZINCRBY。在这种模式下,只有a可以指定单个元素/分数对,分数是数量现有的分数将增加到。使用此模式时ZADD的返回值将是元素的新分数。
LT - 仅在新分数小于时更新现有元素当前分数。这个标志不会阻止添加新元素。
GT - 仅在新分数大于时更新现有元素当前分数。这个标志不会阻止添加新元素。
'''
connect.zadd('test',{'key1': 20,'key2': 10})
  1. connect.zcard(name) 获取元素集合中的个数
  2. connect.zrange(name, start, end, desc=False, withscores=False, score_cast_func=float) 按照索引范围获取name对应的有序集合的元素
'''
name - redis的name
start - 有序集合索引起始位置(非分数)
end - 有序集合索引结束位置(非分数)
desc - 排序规则,默认按照分数从小到大排序
withscores - 是否获取元素的分数,默认只获取元素的值
score_cast_func - 对分数进行数据转换的函数
'''
connect.zrange('test',0,1,withscores=True)
  1. connect.zrevrange(name, start, end, withscores=False, score_cast_func=float) 从大到小排序(同zrange默认排序,集合是从大到小排序的)
  2. connect.zrangebyscore(name, min, max, start=None, num=None, withscores=False, score_cast_func=float) 按照分数范围获取name对应的有序集合的元素
'''
name - redis的name
min - 最小值
max - 最大值
start - 有序集合索引起始位置(非分数)
num - 获取数量
withscores - 是否获取元素的分数,默认只获取元素的值
score_cast_func - 对分数进行数据转换的函数
'''
connect.zrangebyscore('test',min=0,max=10,start=0,num=1,withscores=True)
  1. connect.zrevrangebyscore(name, max, min, start=None, num=None, withscores=False, score_cast_func=float) 按照分数范围获取有序集合的元素并排序(默认从大到小排序)
  2. connect.zscan(name, cursor=0, match=None, count=None, score_cast_func=float) 获取所有元素
  3. connect.zscan_iter(name, match=None, count=None, score_cast_func=float) 获取所有元素--迭代器
  4. connect.zcount(name, min, max) 获取name对应的有序集合中分数 在 [min,max] 之间的个数
  5. connect.zincrby(name, value, amount) 自增
  6. connect.zrank(name, value) 获取索引,按照分数顺序(从小到大)
  7. connect.zrevrank(name, value) 获取索引,按照倒序(从大到小)
  8. connect.zrem(name, value1,value2,...) 删除name对应的有序集合中值是values的成员
  9. connect.zremrangebyrank(name, min, max) 根据索引范围删除
  10. connect.zremrangebyscore(name, min, max) 根据分数范围删除
  11. connect.zscore(name, value) 获取对应值的分数

九、其他函数,异步需要使用async await

  1. connect.close() 关闭Redis连接
  2. connect.select(index) 切换数据库
connect.select(0)
connect.select(1)
connect.select(2)
  1. connect.ping() 判断服务器是否连接成功
  2. connect.echo(str) 从服务器输出字符串
  3. connect.dbsize() 返回服务器中的键数
  4. connect.keys(pattern) 返回匹配' ' pattern ' '的键列表,不传返回全部
  5. connect.scan_iter(match,count) 返回匹配match键迭代器,不传返回全部
  6. connect.time() 返回服务器时间为包含两个元素的int元组
  7. connect.lastsave()返回一个Python datetime对象,表示对象最后一次使用的时间
  8. connect.save() 保存数据
  9. connect.bgsave() 异步保存数据
  10. connect.shutdonw(save= False,nosave = False,now = False,force = False,abort = False,) 如果Redis配置了持久化,数据将在关机前被刷新
'''
save - 也会强制执行DB保存操作
nosave - 将阻止数据库保存操作,即使有一个或多个保存点配置
now - 跳过等待滞后副本,即它绕过了第一步关机顺序
force - 忽略任何通常会阻止服务器退出的错误
abort - 取消正在进行的关机,不能与其他标志结合使用
'''
  1. connect.move(name,db) 将键name移动到另一个数据库 db
  2. connect.flushall(asynchronous = False) 删除当前主机上所有数据库中的所有键,asynchronous 是否异步
  3. connect.flushdb(asynchronous = False) 删除当前数据库中的所有键,asynchronous 是否异步
  4. connect.dump(name) 返回存储在指定键处的值的序列化版本
  5. connect.type(name) 返回键类型
  6. connect.rename(src,dst) 重命名键src为dst
  7. connect.renamex(src,dst) 如果dst不存在,则将src重命名为dst
  8. connect.delete(names) 删除一个或多个由names指定的键
  9. connect.exists(names) 一个或多个由'names指定的键是是否存在
  10. connect.expire(name,time,nx = False,xx= False,gt = False,lt = False) 使用给定在键name上为time秒设置一个过期标志
'''
name - redis的name
time - 过期时间
nx - 仅当密钥没有过期时设置过期
xx - 仅当密钥已存在过期时才设置过期
gt - 仅当新过期时间大于当前过期时间时设置过期时间
lt - 仅在新到期时间小于当前到期时间时设置到期时间
'''
  1. connect.expireat(name,when,nx = False,xx= False,gt = False,lt = False) 使用给定的“选项”在键name上设置一个过期标志
'''
name - redis的name
when - 可以表示为整数表示unix时间或Python datetime对象
nx - 仅当密钥没有过期时设置过期
xx - 仅当密钥已存在过期时才设置过期
gt - 仅当新过期时间大于当前过期时间时设置过期时间
lt - 仅在新到期时间小于当前到期时间时设置到期时间
'''
  1. connect.pexpire(name,time,nx = False,xx= False,gt = False,lt = False) 使用给定在键name上为timeh毫秒设置一个过期标志
'''
name - redis的name
time - 过期时间
nx - 仅当密钥没有过期时设置过期
xx - 仅当密钥已存在过期时才设置过期
gt - 仅当新过期时间大于当前过期时间时设置过期时间
lt - 仅在新到期时间小于当前到期时间时设置到期时间
'''
  1. connect.pexpireat(name,when,nx = False,xx= False,gt = False,lt = False) 使用给定的“选项”在键name上设置一个过期标志
'''
name - redis的name
when - 可以表示为整数表示unix时间或Python datetime对象
nx - 仅当密钥没有过期时设置过期
xx - 仅当密钥已存在过期时才设置过期
gt - 仅当新过期时间大于当前过期时间时设置过期时间
lt - 仅在新到期时间小于当前到期时间时设置到期时间
'''
  1. connect.ttl(name) 返回键name到期前的秒数
  2. connect.pttl(name) 返回键name到期前的毫秒数
  3. connect.persist(name) 删除name的过期

十、连接池,异步需要使用async await

  1. redis.ConnectionPool(option) option参数大部分和redis.Redis一致
import redis

pool = redis.ConnectionPool(host='127.0.0.1',port=6379,decode_responses=True)

connect = redis.Redis(connection_pool=pool)
connect.set('name','数据库0')

print(connect.get('name'))
  1. redis.BlockingConnectionPool(option) option参数大部分和redis.Redis一致

BlockingConnectionPool和ConnectionPool功能是一样的,但是是线程安全的,在多线程的环境下,建议用BlockingConnectionPool,比如gunicorn使用了多线程的worker。同时,当所有连接都在使用时,获取可用连接不会抛异常,而是可以设置等待时间。

相关推荐

几种 TCP 连接中出现 RST 的情况

现在是一个网络时代了。应该不少程序员在编程中需要考虑多机、局域网、广域网的各种问题。所以网络知识也是避免不了学习的。而且笔者一直觉得TCP/IP网络知识在一个程序员知识体系中必需占有一席之地的。在...

Redis连接使用报RDB error错误

该错误信息:Errorinexecution;nestedexceptionisio.lettuce.core.RedisCommandExecutionException:MISC...

lua 语法介绍与 NGINX lua 高级用法实战操作

一、概述lua是一种轻量小巧的脚本语言,用标准C语言编写并以源代码形式开放,其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。官网:https://www.lua.org/二、l...

Python教程——20.协程 - 2

异步编程asyncio.Future对象Task继承Future,Task对象内部中的await结果的处理基于Future对象来的在Future对象中会保存当前执行的这个协程任务的状态,如果当...

“我的足迹”、“浏览历史”,Redis如何快速记录与展示?

咱们在网上“买买买”、“逛逛逛”的时候,总会留下各种各样的“足迹”。无论是电商APP里你最近浏览过的商品,视频网站上你刚刚看过的剧集,还是新闻客户端里你点开过的文章……这些“历史记录”,有时候还真挺有...

你手机上的“消息推送”,Redis可能参与其中

手机上那些时不时就“叮咚”一下的消息推送,确实是咱们数字生活里不可或缺的一部分。这篇咱们就来聊聊,Redis这位“消息灵通人士”,是如何在这场“信息接力赛”中大显身手,确保那些重要的、有趣的通知,能够...

短视频APP的“附近的人”,Redis如何快速匹配?

刷短视频,除了看各种搞笑段子、才艺展示,有时候是不是也想看看“同城”或者“附近”的人都在发些啥有意思的内容?或者,平台也会时不时地给你推荐一些“附近正在直播”的主播,让你感觉一下子拉近了和这个虚拟世界...

微信朋友圈的点赞、评论,Redis在背后默默付出

微信朋友圈,这片小小的“自留地”,承载了我们多少喜怒哀乐、生活点滴啊!一张精心修饰的照片,一段随感而发的文字,发出去之后,最期待的是什么?那必须是屏幕下方不断冒出来的小红心和一条条真诚(或者商业互吹)...

网站登录老是掉线?Redis帮你记住你是谁!

有没有过这样的糟心体验?你好不容易登录了一个网站,刚看了两篇帖子,或者购物车里刚加了几件宝贝,结果一刷新页面,或者稍微离开了一会儿,回来就发现——“哎?我怎么又退出了?!”又得重新输入用户名、密码、...

你常用的APP,哪些地方可能用到了Redis?(猜想与分析)

咱们现在的生活,简直是离不开各种各样的手机APP了!从早上睁眼刷新闻,到中午点外卖,再到晚上刷短视频、玩游戏,一天到头,指尖在屏幕上就没停过。这些APP为了让我们用得爽、用得顺心,背后可是使出了浑身解...

Redis是啥?为啥程序员天天挂嘴边?小白也能看懂!

这Redis到底是何方神圣?为啥那些天天在电脑前敲代码的程序员小哥哥小姐姐们,老是把它挂在嘴边,好像离了它地球都不转了似的?别担心,咱们今天不说那些听了就头大的代码和术语,就用大白话,保证你听完一拍大...

面试官:请你说说Redis为什么这么快?

1)Redis是基于内存的存储数据库,绝大部分的命令处理只是纯粹的内存操作,内存的读写速度非常快。2)Redis是单进程线程的服务(实际上一个正在运行的RedisServer肯定不止一个线程,但只有...

有了强大的关系型数据库,为什么还需要Redis?

在数字世界的浩瀚海洋中,关系型数据库,例如我们熟知的MySQL、PostgreSQL或Oracle,无疑是那些承载着核心业务数据、坚如磐石的“国家图书馆”或“银行金库”。它们以严谨的结构、强大的事务处...

Java 中间件数据可靠性串讲:从 MQ 、MySQL、Redis 不丢失的保障之道

引言在现代分布式系统中,中间件扮演着至关重要的角色,它们是构建高可用、高性能、高可扩展应用架构的基石。消息队列(MQ)、数据库(如MySQL)、缓存(如Redis)等是其中最具代表性的组件。然而,...

运维部署方式之——虚机部署

标准化使用作業系统:LinuxCentOS7自动化方式通过Ansible系统初始化playbook来管理。目的系统初始化工作是一个简单、繁复的工作,从云网得到的虚拟主机只是一个基础的系统环境,...

取消回复欢迎 发表评论: