python连接redis

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介:

一、安装服务

下载、编译安装

1
2
3
4
wget http: //download .redis.io /releases/redis-3 .0.1. tar .gz
tar  -zxvf redis-3.0.1. tar .gz
cd  redis-3.0.1
make


二进制文件是编译完成后在src目录下,通过下面的命令启动Redis服务:

1
$ src /redis-server  &


客户端也可以如下安装:

1
pip  install  redis



二、redis连接示例

    redis是以key-value的形式存储的。首先我们将redis所在主机的ip和发布端口作为参数实例化了一个对象r,然后去设置set和取出get值。


例子:

1
2
3
4
5
6
7
8
9
import  redis
redis_config  =  {
"host" "192.168.2.230" ,
"port" 6379
}
=  redis.Redis( * * redis_config)
r. set ( "name" , "huangzhenping" )
print (r.keys())
print (r.get( "name" ))


运行结果:

name

huangzhenping



三、连接池

    redis-py使用connection pool来管理对一个redis server的所有连接,避免每次建立、释放连接的开销。默认,每个Redis实例都会维护一个自己的连接池。可以直接建立一个连接池,然后作为参数Redis,这样就可以实现多个Redis实例共享一个连接池


例子:

1
2
3
4
5
6
7
8
9
import  redis
redis_config  =  {
     "host" "192.168.2.230" ,
     "port" 6379
}
pool  =  redis.ConnectionPool( * * redis_config)
=  redis.Redis(connection_pool = pool)
r. set ( "age" , "27" )
print (r.get( "age" ))


运行结果:

27


或者将连接池包装成一个函数,方便调用:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
import  redis
def  get_redis_connect():
     redis_config  =  {
         "host" "192.168.2.230" ,
         "port" 6379
     }
     
     pool  =  redis.ConnectionPool( * * redis_config)
     =  redis.Redis(connection_pool = pool)
     return  r
     
if  __name__  = =  "__main__" :
     =  get_redis_connect()
     print (r.keys())



四、管道

    redis-py默认在执行每次请求都会创建(连接池申请连接)和断开(归还连接池)一次连接操作,如果想要在一次请求中指定多个命令,则可以使用pipline实现一次请求指定多个命令,并且默认情况下一次pipline 是原子性操作。redis服务端会处理完多条命令后会将多条命令的处理结果打包到一起返回给客户端。需要注意到是redis必须在处理完所有命令前先缓存起所有命令的处理结果,打包的命令越多,缓存消耗内存也越多。


例子:对比使用管道和不使用管道处理的时间

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import  redis
import  datetime
def  withpipe(r):
     pipe  =  r.pipeline(transaction = True )
     for  in  xrange ( 1 1000 ):
         key  =  "key1_"  +  str (i)
         value  =  "value1_"  +  str (i)
         pipe. set (key, value)
     pipe.execute()
     
def  withoutpipe(r):
     for  in  xrange ( 1 1000 ):
         key  =  "key2_"  +  str (i)
         value  =  "value2_"  +  str (i)
         r. set (key, value)
         
redis_config  =  {
     "host" "192.168.2.230" ,
     "port" 6379 ,
     "db" 0
}
 
if  __name__  = =  "__main__" :
     pool  =  redis.ConnectionPool( * * redis_config)
     r1  =  redis.Redis(connection_pool = pool)
     r2  =  redis.Redis(connection_pool = pool)
     start  =  datetime.datetime.now()
     
     withpipe(r1)
     end  =  datetime.datetime.now()
     t_time  =  (end  -  start).microseconds
     print ( "withpipe time is: {0}" . format (t_time))
     start  =  datetime.datetime.now()
     
     withoutpipe(r2)
     end  =  datetime.datetime.now()
     t_time  =  (end  -  start).microseconds
     print ( "withoutpipe time is: {0}" . format (t_time))


运行结果:

withpipe time is: 17000

withoutpipe time is: 105000










本文转自 huangzp168 51CTO博客,原文链接:http://blog.51cto.com/huangzp/2043948,如需转载请自行联系原作者
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
6天前
|
NoSQL Redis 数据库
Redis 连接
10月更文挑战第19天
15 0
|
4天前
|
关系型数据库 MySQL 数据库连接
python脚本:连接数据库,检查直播流是否可用
【10月更文挑战第13天】本脚本使用 `mysql-connector-python` 连接MySQL数据库,检查 `live_streams` 表中每个直播流URL的可用性。通过 `requests` 库发送HTTP请求,输出每个URL的检查结果。需安装 `mysql-connector-python` 和 `requests` 库,并配置数据库连接参数。
97 68
|
5天前
|
NoSQL 网络协议 算法
Redis 客户端连接
10月更文挑战第21天
12 1
|
16天前
|
IDE 网络安全 开发工具
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
本文介绍了如何在PyCharm专业版中连接远程服务器并配置远程Python环境解释器,以便在服务器上运行代码。
121 0
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
|
14天前
|
SQL Oracle 关系型数据库
Python连接Oracle
Python连接Oracle
13 0
|
2月前
|
NoSQL Linux Redis
linux安装单机版redis详细步骤,及python连接redis案例
这篇文章提供了在Linux系统中安装单机版Redis的详细步骤,并展示了如何配置Redis为systemctl启动,以及使用Python连接Redis进行数据操作的案例。
53 2
|
2月前
|
Unix Linux 网络安全
python中连接linux好用的模块paramiko(附带案例)
该文章详细介绍了如何使用Python的Paramiko模块来连接Linux服务器,包括安装配置及通过密码或密钥进行身份验证的示例。
46 1
|
23天前
|
消息中间件 存储 NoSQL
python 使用redis实现支持优先级的消息队列详细说明和代码
python 使用redis实现支持优先级的消息队列详细说明和代码
33 0
|
23天前
|
Android开发 Swift iOS开发
python 基于电脑蓝牙连接获取手机的实时数据
python 基于电脑蓝牙连接获取手机的实时数据
36 0
|
3月前
|
NoSQL 算法 Java
诡异!Redis Proxy RT上升后连接倾斜
本文细致地描述了关于Redis Proxy RT上升后连接倾斜问题的排查过程和根本原因,最后给出了优化方案。