Python에서 Redis를 어떻게 사용하나요? 다음 글에서는 Python에서 Redis를 사용하는 방법을 소개하겠습니다. 도움이 되길 바랍니다.
이전에는 Redis
를 사용하기 위해 Redis
클라이언트를 사용했지만, 실제 작업에서는 대부분 코드Redis
를 통해 사용하는데, 편집자는 Python
에 익숙하므로 오늘은 Python
을 사용하여 Redis
를 작동하는 방법을 알아 보겠습니다. [관련 권장사항: Redis 동영상 튜토리얼]Redis
客户端对 Redis
进行使用的,但是实际工作中,我们大多数情况下都是通过代码来使用 Redis
的,由于小编对 Python
比较熟悉,所以我们今天就一起来学习下如何使用 Python
来操作 Redis
。【相关推荐:Redis视频教程】
Redis
首先需要安装好。Python
安装好(建议使用 Python3
)。Redis
的 Python
库安装好(pip install redis
)。例:我们计划通过 Python
连接到 Redis
。然后写入一个 kv
,最后将查询到的 v
打印出来。
#!/usr/bin/python3 import redis # 导入redis模块 r = redis.Redis(host='localhost', port=6379, password="pwd@321", decode_responses=True) # host是redis主机,password为认证密码,redis默认端口是6379 r.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/python3 import redis,time # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库 pool = redis.ConnectionPool(host='localhost', port=6379, password="pwd@321", decode_responses=True) # host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379 r = 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></int> 过期时间(m) |
px |
<int></int> 过期时间(ms) |
nx |
<bool></bool> 如果为真,则只有 name 不存在时,当前 set 操作才执行 |
xx |
<bool></bool> 환경 준비
연습 시작시도해 보기 | 예: 우리의 계획
🎜get
은 연결 풀에서 실행되는 마지막 명령입니다. 🎜
redis
에 연결해야 할 때 연결이 생성되고 이를 기반으로 합니다. 연결redis 작업이 완료되면 해제하세요. 일반적인 상황에서는 문제가 되지 않지만, 동시성 양이 높을 경우 연결 생성 및 해제를 자주 수행하면 성능에 큰 영향을 미치므로 연결 풀이 작동하게 됩니다. 🎜🎜연결 풀의 원칙: 미리 여러 개의 연결을 생성하세요. redis
작업을 수행할 때 이미 생성된 연결을 직접 가져와서 작업하세요. 완료 후에는 연결이 해제되지 않지만 후속 redis
작업을 위해 연결 풀로 반환됩니다! 이렇게 하면 지속적인 생성 및 릴리스가 방지되어 성능이 향상됩니다! 🎜#!/usr/bin/python3 import redis,time # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库 pool = redis.ConnectionPool(host='localhost', port=6379, password="pwd@321", decode_responses=True) # host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379 r = 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')))🎜🎜🎜실제 사용에서는 직접 연결의 효과와 연결 풀의 사용 효과는 동일하지만 높은 동시성에서는 분명한 차이가 있음을 알 수 있습니다. 🎜
Redis
명령의 경우 여기서는 SET
을 사용합니다. 명령 예시로 표시됩니다. 🎜🎜형식: redis-py 매개변수의 set(name, value, ex=None, px=None, nx=False, xx=False)
🎜🎜 설정 명령: 🎜매개변수 이름 | 해석 | 🎜ex🎜 |
<int></int> 만료 시간(분)🎜🎜 |
---|---|
px🎜 |
<int></int> 만료 시간(ms)🎜🎜 |
nx🎜 |
<bool></bool> true이면 현재 설정 작업은 이름이 존재하지 않는 경우에만 실행됩니다🎜🎜 |
<bool></bool> true이면 현재 설정 작업은 이름이 존재할 때만 실행됩니다🎜🎜🎜🎜ex我们计划创建一个 #!/usr/bin/python3 import redis,time # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库 pool = redis.ConnectionPool(host='localhost', port=6379, password="pwd@321", decode_responses=True) # host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379 r = redis.Redis(connection_pool=pool) r.set('name', 'phyger-from-python-redis',ex=3) print(r['name']) # 应当有v time.sleep(3) print(r.get('name')) # 应当无v print(type(r.get('name'))) nx由于 px 的单位太短,我们就不做演示,效果和 ex 相同。 我们计划去重复 #!/usr/bin/python3 import redis,time # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库 pool = redis.ConnectionPool(host='localhost', port=6379, password="pwd@321", decode_responses=True) # host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379 r = 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')))
xx我们计划去重复 #!/usr/bin/python3 import redis,time # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库 pool = redis.ConnectionPool(host='localhost', port=6379, password="pwd@321", decode_responses=True) # host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379 r = 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')))
更多编程相关知识,请访问:编程视频!! |
위 내용은 Python에서 Redis를 사용하는 방법에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!