python连接redis

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容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
目录
相关文章
|
2月前
|
NoSQL Redis 数据库
Redis 连接
10月更文挑战第19天
35 0
|
1月前
|
关系型数据库 MySQL 数据库连接
python脚本:连接数据库,检查直播流是否可用
【10月更文挑战第13天】本脚本使用 `mysql-connector-python` 连接MySQL数据库,检查 `live_streams` 表中每个直播流URL的可用性。通过 `requests` 库发送HTTP请求,输出每个URL的检查结果。需安装 `mysql-connector-python` 和 `requests` 库,并配置数据库连接参数。
132 68
|
4天前
|
NoSQL 应用服务中间件 API
Redis是如何建立连接和处理命令的
本文主要讲述 Redis 是如何监听客户端发出的set、get等命令的。
|
1月前
|
监控 NoSQL 网络协议
【Azure Redis】部署在AKS中的应用,连接Redis高频率出现timeout问题
查看Redis状态,没有任何异常,服务没有更新,Service Load, CPU, Memory, Connect等指标均正常。在排除Redis端问题后,转向了AKS中。 开始调查AKS的网络状态。最终发现每次Redis客户端出现超时问题时,几乎都对应了AKS NAT Gateway的更新事件,而Redis服务端没有任何异常。因此,超时问题很可能是由于NAT Gateway更新事件导致TCP连接被重置。
|
2月前
|
NoSQL 网络协议 算法
Redis 客户端连接
10月更文挑战第21天
40 1
|
2月前
|
IDE 网络安全 开发工具
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
本文介绍了如何在PyCharm专业版中连接远程服务器并配置远程Python环境解释器,以便在服务器上运行代码。
454 0
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
|
1月前
|
测试技术 API 数据安全/隐私保护
Python连接到Jira实例、登录、查询、修改和创建bug
通过使用Python和Jira的REST API,可以方便地连接到Jira实例并进行各种操作,包括查询、修改和创建Bug。`jira`库提供了简洁的接口,使得这些操作变得简单易行。无论是自动化测试还是开发工作流的集成,这些方法都可以极大地提高效率和准确性。希望通过本文的介绍,您能够更好地理解和应用这些技术。
154 0
|
2月前
|
SQL Oracle 关系型数据库
Python连接Oracle
Python连接Oracle
26 0
|
3月前
|
NoSQL Linux Redis
linux安装单机版redis详细步骤,及python连接redis案例
这篇文章提供了在Linux系统中安装单机版Redis的详细步骤,并展示了如何配置Redis为systemctl启动,以及使用Python连接Redis进行数据操作的案例。
91 2
|
3月前
|
Unix Linux 网络安全
python中连接linux好用的模块paramiko(附带案例)
该文章详细介绍了如何使用Python的Paramiko模块来连接Linux服务器,包括安装配置及通过密码或密钥进行身份验证的示例。
144 1