python连接redis

本文涉及的产品
云数据库 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
目录
相关文章
|
1月前
|
Python
利用Python生成字符串连接
利用Python生成字符串连接
19 0
|
1月前
|
NoSQL 网络安全 Redis
用Windows连接Liunx中的redis
用Windows连接Liunx中的redis
23 0
|
19天前
|
缓存 运维 NoSQL
【Redis故障排查】「连接失败问题排查和解决」带你总体分析和整理Redis的问题故障实战开发指南及方案
【Redis故障排查】「连接失败问题排查和解决」带你总体分析和整理Redis的问题故障实战开发指南及方案
45 0
|
1月前
|
SQL 关系型数据库 MySQL
用 Python 连接数据库并进行查询。
【2月更文挑战第12天】【2月更文挑战第32篇】用 Python 连接数据库并进行查询。
|
12天前
|
网络协议 安全 Python
python监听连接请求
【4月更文挑战第5天】本教程介绍了网络编程中服务器监听连接请求的关键步骤。首先,理解监听是服务器在特定端口等待客户端连接的基本概念。接着,设置监听涉及创建套接字、绑定地址和端口,以及开始监听。提供了一个Python示例,展示如何使用socket库实现监听。注意点包括异常处理、并发处理和安全性考虑。学习后,读者能掌握基础的监听连接请求代码编写。
|
14天前
|
NoSQL 安全 网络安全
Redis连接:加速数据访问与保障安全传输的关键
Redis连接:加速数据访问与保障安全传输的关键
|
25天前
|
Cloud Native NoSQL 数据管理
Serverless 应用引擎常见问题之首次启动获取不到redis连接如何解决
Serverless 应用引擎(Serverless Application Engine, SAE)是一种完全托管的应用平台,它允许开发者无需管理服务器即可构建和部署应用。以下是Serverless 应用引擎使用过程中的一些常见问题及其答案的汇总:
28 3
Serverless 应用引擎常见问题之首次启动获取不到redis连接如何解决
|
1月前
|
网络协议 Python
Python网络编程实现TCP和UDP连接
Python网络编程实现TCP和UDP连接
26 0
|
1月前
|
存储 NoSQL Redis
如何在Python中操作Redis数据库
如何在Python中操作Redis数据库
27 0
|
1月前
|
SQL 关系型数据库 MySQL
使用pymysql工具包连接Python与数据库
使用pymysql工具包连接Python与数据库
33 0