redis库提供了两个类:Redis和StrictRedis来实现Redis的命令操作,前者是为了兼容老版本库的集中方法,一般就用StrictRedis

一. redis基本操作

. 设置redis密码
在redis.conf中找到requirepass行,修改后面的参数,即可设置密码
比如requirepass ,重启生效 . 源码安装的重启方法
redis-cli进入命令行,然后shutdown即可 . 启动方法
redis-server redis.conf . 输入密码方法: 进入命令行后,执行auth

二. 键的一些判断和操作方法

方法 作用 参数说明 示例 示例说明 示例结果
exists(name) 判断一个值是否存在 name:键名 redis.exists('name') 是否存在name这个键 True
delete(name) 删除一个键 name:键名 redis.delete('name') 删除name这个键 1
type(name) 判断键类型 name:键名 redis.type('name') 判断name这个键类型 b'string'
keys(pattern) 获取所有符合规则的键 pattern:匹配规则 redis.keys('n*') 获取所有以n开头的键 [b'name']
randomkey() 获取随机的一个键   randomkey() 获取随机的一个键 b'name'
rename(str, dst) 重命名键 src:原键名;dst:新键名 redis.rename('name', 'newname' 将name重命名为newname True
dbsize() 获取当前数据库中键的数目   dbsize() 当前数据库中键的数目 100
expire(name, time) 设置键的过期时间,单位为秒 name:键名; time:秒数 redis.expire('name', 2) name键的过期时间为2秒 True
ttl(name) 获取键的过期时间 name:键名 redis.ttl('name') -1表示永不过期 -1
move(name, db) 将键移动到其他数据库 name:键名;db:数据库代号 move('name', 2) 将name移动到2号数据库 True
flushdb() 删除当前数据库中的所有键   flushdb()   True
flushall() 删除所有数据库中的所有键   flushall()   True

三. 字符串操作

# 连接Redis
>>> from redis import StrictRedis
>>> redis = StrictRedis(host='localhost', port=, db=, password='') 1. 给name键赋值为Bob
>>> redis.set('name', 'Bob')
True 2. 返回name键的值
>>> redis.get('name')
b'Bob' 3. 给name键赋值,并返回上次的value
>>> redis.getset('name','Mike')
b'Bob'
>>> redis.get('name')
b'Mike' 4. 返回多个键对应的值
>>> redis.mget(['name','nickame'])
[b'Mike', None]
>>> redis.set('nickname', 'bob')
True
>>> redis.mget(['name','nickname'])
[b'Mike', b'bob'] 5. 如果键不存在,则赋值
>>> redis.setnx('newname', 'James')
True
>>> redis.setnx('newname', 'James')
False
>>> redis.get('newname')
b'James' 6. 给键名赋值,并设定过期时间
>>> redis.setex('name', , 'James')
True 7. 设置name为Hello,并在index为5的位置补上'World'字符串
>>> redis.set('name','Hello')
True
>>>
>>> redis.setrange('name',,'World') >>> redis.get('name')
b'HelloWorld' 8. 设置多个键值对
>>> redis.mset({'name1':'durant', 'name2':'James'})
True
>>> redis.get('name1')
b'durant'
>>> redis.get('name2')
b'James' 9. 在键不存在时,才设置键的值
>>> redis.mset({'name3':'durant', 'name4':'James'})
>>> redis.msetnx({'name3':'jin', 'name4':'hong'})
False
>>> redis.get('name3')
b'durant'
>>> redis.get('name4')
b'James'
>>> 10. 键对应的值增1,若不存在此键,则会创建并赋值为1
>>> redis.incr('age',) >>> redis.get('age')
b'' 11. age键对应的值减1,若不存在,则会创建此键并设置为-1
>>> redis.decr('age',) 12. 向键为nickname的值后追加‘OK'字符
>>> redis.append('nickname', 'OK') >>> redis.get('nickname')
b'bobOK' 13. 返回name值索引为1-4的字符
>>> redis.substr('name',,)
b'ello'
>>> redis.getrange('name',,)
b'ello'

四. 列表操作

1. 向键为list的列表末尾添加1,2,3,4,5
>>> redis.rpush('list',,,,,) 2. 向键为list的列表头部添加0
>>> redis.lpush('list',) 3. 返回键为list的列表的长度
>>> redis.llen('list') 4. 返回起始索引为0到5对应的列表
>>> redis.lrange('list',,)
[b'', b'', b'', b'', b'', b''] 5. 保留索引1-5对应的列表
>>> redis.ltrim('list',,)
True 6. 返回键为list的列表索引为1的元素
>>> redis.lindex('list',)
b'' 7. 将list列表索引为1的位置赋值为5
>>> redis.lset('list',,)
True
>>> redis.lindex('list',)
b'' 8. 删除列表中的多个值,2表示两个,5表示值
>>> redis.lrem('list',,)
#表示删除的个数,如果列表中只有一个5,则返回1
>>> redis.lrange('list',,)
[b'', b'', b''] 9. 返回并删除列表中的第一个元素
>>> redis.lpop('list')
b'' 10. 返回并删除列表中的最后一个元素
>>> redis.rpop('list')
b'' 11. 返回并删除列表中的首个元素,如果列表为空,并设置timeout=0时,则会一直阻塞等待
>>> redis.blpop('list')
(b'list', b'')
>>> redis.blpop('list',timeout=) 此时列表已经为空,等待一秒后输出空
>>> 12. 返回并删除列表中的最后一个元素,和rpop的区别是里面可加timeout参数
>>> redis.rpush('list',,,) >>> redis.brpop('list')
(b'list', b'') 13. 删除列表list的尾元素,并将其添加到列表list2的头部
>>> redis.rpoplpush('list','list2')
b''
>>> redis.lindex('list2',)
b''

Redis存储的更多相关文章

  1. nginx+iis+redis+Task.MainForm构建分布式架构 之 (redis存储分布式共享的session及共享session运作流程)

    本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,上一篇分享文章制作是在windows上使用的nginx,一般正式发布的时候是在linux来配 ...

  2. Redis存储Tomcat集群的Session

    Redis存储Tomcat集群的Session 如何 做到把新开发的代码推送到到生产系统中部署,生产系统要能够零宕机.对使用用户零影响. 设想 是使用集群来搞定,通过通知负载均衡Nginx,取下集群中 ...

  3. redis 存储session实现session共享

    nginx 作为代理 tomcat集群 redis存储共享session nginx采用轮询方式将动态请求反向代理给tomcat,tomcat通过加载相应jar包方式实现获得redis中共享的sess ...

  4. Tomcat 使用Redis存储Session

    Tomcat Redis Session Github 地址. 下载 commons-pool2-2.2.jar,jedis-2.5.2.jar,tomcat-redis-session-manage ...

  5. Asp.net Core 使用Redis存储Session

    前言 Asp.net Core 改变了之前的封闭,现在开源且开放,下面我们来用Redis存储Session来做一个简单的测试,或者叫做中间件(middleware). 对于Session来说褒贬不一, ...

  6. php使用redis存储

    一.Redis扩展模块 # wget https://codeload.github.com/phpredis/phpredis/zip/develop -O phpredis.zip # unzip ...

  7. Redis 存储、查询

    [TOC] 数据存储 假设我们在MySQL数据库中有这样一张表: mysql> desc user_info; Field Type Null Key Default Extra id int( ...

  8. Redis存储Session

    net Core 使用Redis存储Session   前言 Asp.net Core 改变了之前的封闭,现在开源且开放,下面我们来用Redis存储Session来做一个简单的测试,或者叫做中间件(m ...

  9. redis存储session配制方法

    redis存储session配制方法需要三个模块: 1.redis 2.express-session 3.connect-redis 项目中的配置方法代码片段如下: 首先连接redis,连接redi ...

  10. 几分钟搞定redis存储session共享——设计实现

    前面我们写过C#在redis中存储常用的5种数据类型demo,没看过的可以点击电梯直达:https://www.cnblogs.com/xiongze520/p/10267804.html 我们上一篇 ...

随机推荐

  1. 使用Git将码云上的代码Clone至本地

    1. 安装Git https://git-scm.com/book/zh/v2/%E8%B5%B7%E6%AD%A5-%E5%AE%89%E8%A3%85-Git Git的网站上有详细的分各种系统的安 ...

  2. 程序的跟踪debug

  3. JS如何判断浏览器类型,如何模拟浏览器类型(模拟微信浏览器)

    一.前言 在编写前端代码时,为了页面兼容性,我们往往需要考虑不同的浏览器类型 而这就需要在前端代码中进行识别和区分 接下来就来谈谈对浏览器类型的识别 二.正文 (一).查看浏览器类型的核心代码 var ...

  4. UNITY录制视屏解决方案 - ShareREC For Unity3D

    注意buildSetting里面,AutoGraphic改成opengl es2,否则魅蓝手机上容易出现1/4屏 一.导入项目 1.到Mob官网下载ShareREC For Unity3D 的SDK包 ...

  5. IPMI总结

    http://www.chenshake.com/summary-of-ipmi/ 记忆的很清楚,2000年的时候,当时还是Compaq,推出第一款远程控制卡,当时听起来非常神奇.可以远程开机,关机, ...

  6. loadrunner--web_url函数用法

    web_url语法:        Int Web_url(const char *name, const char * url, <Lists of Attributes>, [EXTR ...

  7. 常见的http response

    200            //OK                                 400            //bad request 401           //Una ...

  8. WCF技术剖析(卷1)WCF全面解析文摘

    第1章 wcf简介 soa体现的是一种对关注点进行分解的思想,与技术无关 soa的基本思想: a.服务自治  独立部署,不依赖其他 b.依赖于开放的标准  采用xml,xsd,及wsdl作为服务描述的 ...

  9. 借用服务器百度BAE

    3一.简介 对于普通的开发者,不必要买服务器和买域名,这时要将自己的项目传到服务器上,就用到了百度BAE这样的,可以直接传项目的服务器. 二.申请 登录百度开放平台上 三.登录网址,选择要使用的项目 ...

  10. Ubuntu的TOOL工具收集

    Ubuntu工具 1. Ubuntu下嵌入式开发环境的搭建 http://www.linuxidc.com/Linux/2011-03/33824.htm