python访问redis

首先说一下在Windows下安装Redis,安装包可以在https://github.com/MSOpenTech/redis/releases中找到,可以下载msi安装文件,也可以下载zip的压缩文件。

下载zip文件之后解压,解压后是这些文件:

里面这个Windows Service Documentation.docx是一个文档,里面有安装指导和使用方法。

也可以直接下载msi安装文件,直接安装,安装之后的安装目录中也是这些文件,可以对redis进行相关的配置。

安装完成之后可以对redis进行测试,双击redis-cli.exe,如果不报错的话,应该会连接上本地的redis,进行简单的测试:

默认安装的是6379端口,测试成功。

也可以输入help,查看帮助:

  1. 127.0.0.1:6379> help
  2. redis-cli 3.2.100
  3. To get help about Redis commands type:
  4. "help @<group>" to get a list of commands in <group>
  5. "help <command>" for help on <command>
  6. "help <tab>" to get a list of possible help topics
  7. "quit" to exit
  8. To set redis-cli perferences:
  9. ":set hints" enable online hints
  10. ":set nohints" disable online hints
  11. Set your preferences in ~/.redisclirc
127.0.0.1:6379> help
redis-cli 3.2.100
To get help about Redis commands type:
      "help @<group>" to get a list of commands in <group>
      "help <command>" for help on <command>
      "help <tab>" to get a list of possible help topics
      "quit" to exit

To set redis-cli perferences:
      ":set hints" enable online hints
      ":set nohints" disable online hints
Set your preferences in ~/.redisclirc

下面说一下用Python操作Redis吧,使用Python安装Redis的话需要安装redis-py的库

1、安装redis-py

easy_install redis  也可以使用pip install redis安装,或者在https://github.com/andymccurdy/redis-py下载然后执行python setup.py install安装

2、安装Parser安装

Parser可以控制如何解析redis响应的内容。redis-py包含两个Parser类,PythonParser和HiredisParser。默认,如果已经安装了hiredis模块,redis-py会使用HiredisParser,否则会使用PythonParser。HiredisParser是C编写的,由redis核心团队维护,性能要比PythonParser提高10倍以上,所以推荐使用。安装方法,使用easy_install:

easy_install hiredis  或者pip install hiredis

3、使用python操作redis

redis-py提供两个类Redis和StrictRedis用于实现Redis的命令,StrictRedis用于实现大部分官方的命令,并使用官方的语法和命令(比如,SET命令对应与StrictRedis.set方法)。Redis是StrictRedis的子类,用于向后兼容旧版本的redis-py。

  1. import redis
  2. r = redis.StrictRedis(host='127.0.0.1', port=6379)
  3. r.set('foo', 'hello')
  4. r.rpush('mylist', 'one')
  5. print r.get('foo')
  6. print  r.rpop('mylist')
import redis

r = redis.StrictRedis(host='127.0.0.1', port=6379)
r.set('foo', 'hello')
r.rpush('mylist', 'one')
print r.get('foo')
print  r.rpop('mylist')

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

  1. pool = redis.ConnectionPool(host='127.0.0.1', port=6379)
  2. r = redis.Redis(connection_pool=pool)
  3. r.set('one', 'first')
  4. r.set('two', 'second')
  5. print r.get('one')
  6. print r.get('two')
pool = redis.ConnectionPool(host='127.0.0.1', port=6379)
r = redis.Redis(connection_pool=pool)
r.set('one', 'first')
r.set('two', 'second')
print r.get('one')
print r.get('two')

redis pipeline机制,可以在一次请求中执行多个命令,这样避免了多次的往返时延。

  1. pool = redis.ConnectionPool(host='127.0.0.1', port=6379)
  2. r = redis.Redis(connection_pool=pool)
  3. pipe = r.pipeline()
  4. pipe.set('one', 'first')
  5. pipe.set('two', 'second')
  6. pipe.execute()
  7. pipe.set('one'. 'first').rpush('list', 'hello').rpush('list', 'world').execute()
pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  
r = redis.Redis(connection_pool=pool)  
pipe = r.pipeline()  
pipe.set('one', 'first')  
pipe.set('two', 'second')  
pipe.execute()  
  
pipe.set('one'. 'first').rpush('list', 'hello').rpush('list', 'world').execute()

redis-py默认在一次pipeline中的操作是原子的,要改变这种方式,可以传入transaction=False

  1. pipe = r.pipeline(transaction=False)
时间: 2024-10-15 09:53:33

python访问redis的相关文章

python访问redis数据库

#!/usr/env/bin python import redis r=redis.Redis(host='localhost',port=6379,db=0) with r.pipeline() as pipe:     while 1:         try:             pipe.watch('OUR-SEQUENCE-KEY')             current_value=pipe.get('OUR-SEQUENCE-KEY')             next_

win10下使用python访问vmbox中的redis

了解到redis没有windows的官方支持,所以在vmbox中的ubuntu装了redis #在ubuntu中 #搜索redis相关软件信息 apt-cache search ^redis #不清楚为什么不加正则符号出现一些毫不相关的,比如下面 #bird-bgp - Internet Routing Daemon [transitional package] #安装redis客户端 apt-get install redis-server #修改redis配置文件,否则宿主ip会被拒绝 su

使用Python操作Redis

1. 安装pyredis 首先安装pip 1 2 3 4 5 6 7 8 <SHELL># apt-get install python-pip ...... <SHELL># pip install --proxy=http://172.1.2.6:8080 redis Downloading redis-2.9.1.tar.gz (62kB): 62kB downloaded Running setup.py (path:/tmp/pip_build_root/redis/se

Redis之Python 使用 Redis

Python 使用 Redis 参考文档: http://redis.cn/clients.html#python https://github.com/andymccurdy/redis-py 安装Redis $ sudo pip install redis 简单的redis操作 字符串string操作 In [1]: import redis In [2]: r = redis.StrictRedis(host='localhost', port=6379, db=0, password='

使用 python 操作 redis

1.安装pyredis (1)使用 # easy_install redis (2)直接编译安装 #wget https://pypi.python.org/packages/source/r/redis/redis-2.9.1.tar.gz #tar xvzf redis-2.9.1.tar.gz #cd redis-2.9.1 #python setup.py install 2.简单的redis操作 redis连接实例是线程安全的,可以直接将redis连接实例设置为一个全局变量,直接使用.

使用Python操作Redis应用场景

1. 安装pyredis 首先安装pip 1 2 3 4 5 6 7 8 <SHELL># apt-get install python-pip ...... <SHELL># pip install --proxy=http://172.1.2.6:8080 redis Downloading redis-2.9.1.tar.gz (62kB): 62kB downloaded Running setup.py (path:/tmp/pip_build_root/redis/se

python中redis的连接和操作

一.redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set --有序集合)和hash(哈希类型).这些数据类型都支持push/pop.add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的.在此基础上,redis支持各种不同方式的排序.与memcached一样,为了保证效率,数据都是缓存在内存中.区别的是redis会周

使用Python操作Redis详解

之前的五天,过了个愉快的周末,然后将公司AbaseDump的调度部分代码看懂并且在此之上完成了OnlyDump的功能代码,代码不可以公开,今天完工,明天测试,晚上来总结一下这几天学到的一点应用. 使用Python操作Redis详解 ------------------------------------------------------------------------------------------------- 一. 文档说明 本文档仅介绍Redis在Python中的使用,Redis

Serverless 解惑——函数计算如何访问 Redis 数据库

函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务.使用函数计算,您无需采购与管理服务器等基础设施,只需编写并上传代码.函数计算为您准备好计算资源,弹性地可靠地运行任务,并提供日志查询.性能监控和报警等功能.借助函数计算,您可以快速构建任何类型的应用和服务,并且只需为任务实际消耗的资源付费. 访问 Redis 数据库是指在函数计算中通过编写代码调用数据库驱动库通过 TCP 协议实现对数据库进行的插入.查询等操作.通常函数计算中运行的不同函数实例之间是不共享状态的,