redis数据库
-
一:nosql介绍
-
二:redis介绍
-
2.1 Redis特性
- 2.2 Redis 优势
- 2.3 redis应用场景
-
三:redis安装配置
-
3.1 redis安装
- 3.2 redis配置
- 3.3 redis启动
- 3.4 使用客户端连接redis
-
四:redis数据类型
-
4.1 string类型
- 4.2 键命令
- 4.3 hash类型
- 4.4 list类型
- 4.5 set类型
- 4.6 zset类型
-
五:redis主从
-
5.1 环境准备
- 5.2 配置主redis
- 5.3 配置从redis
- 5.4 查看主从关系
- 5.5 数据操作
-
六:redis常用操作总结
-
6.1 设置键值
- 6.2 设置键值对的过期时间
- 6.3 hash,哈希操作
- 6.4 列表(list)操作 (可以存储重复值)
- 6.5 set集合(集合没有重复值)的操作
- 6.6 事务操作
- 6.7 发布/订阅操作
- 6.8 持久化
-
七:python与redis交互
-
7.1 python安装redis
- 7.2 StrictRedis对象⽅法
- 7.3 字符串的操作
- 7.4 列表的操作
- 7.5 集合的操作
- 7.6 哈希(hash)的操作
- 7.7 事务(管道)操作
- 7.8 发布与订阅
- 7.9 django-redis
一:nosql介绍
NoSQL:一类新出现的数据库(not only sql),它的特点:
- 不支持SQL语法
- 存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是KV形式
- NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
- NoSQL中的产品种类相当多:
Mongodb
Redis
Hbase hadoop
Cassandra hadoop
NoSQL和SQL数据库的比较:
- 适用场景不同:sql数据库适合用于关系特别复杂的数据查询场景,nosql反之
- “事务”特性的支持:sql对事务的支持非常完善,而nosql基本不支持事务
- 两者在不断地取长补短,呈现融合趋势
二:redis介绍
Redis官方网站:
1
2
3
4 1官网:https://redis.io/
2中文官网:http://redis.cn/
3
4
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色
2.1 Redis特性
Redis 与其他 key – value 缓存产品有以下三个特点:
- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
- Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
- Redis支持数据的备份,即master-slave模式的数据备份。
2.2 Redis 优势
- 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
- 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
- 原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
- 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
2.3 redis应用场景
- 用来做缓存(ehcache/memcached)——redis的所有数据是放在内存中的(内存数据库)
- 可以在某些特定应用场景下替代传统数据库——比如社交类的应用
- 在一些大型系统中,巧妙地实现一些特定的功能:session共享、购物车
- 只要你有丰富的想象力,redis可以用在可以给你无限的惊喜…….
三:redis安装配置
3.1 redis安装
环境:ubuntu16.04
1
2
3
4
5
6
7
8
9
10
11
12 1wget http://download.redis.io/releases/redis-3.2.8.tar.gz # 稳定版本3.2
2tar -zxvf redis-3.2.8.tar.gz
3cd redis-3.2.8/
4mkdir /application/
5make
6make PREFIX=/application/redis-3.2.8 install
7mkdir /application/redis-3.2.8/conf
8cp redis.conf /application/redis-3.2.8/conf/
9cd /application/
10ln -s redis-3.2.8 redis
11
12
安装完成后查看redis的核心文件有:
1
2
3
4
5
6
7
8
9
10 1root@ubuntu:/application/redis# ll bin
2total 16292
3-rwxr-xr-x 1 root root 2683048 Feb 26 14:25 redis-benchmark*
4-rwxr-xr-x 1 root root 28856 Feb 26 14:25 redis-check-aof*
5-rwxr-xr-x 1 root root 5548408 Feb 26 14:25 redis-check-rdb*
6-rwxr-xr-x 1 root root 2859520 Feb 26 14:25 redis-cli*
7lrwxrwxrwx 1 root root 12 Feb 26 14:25 redis-sentinel -> redis-server*
8-rwxr-xr-x 1 root root 5548408 Feb 26 14:25 redis-server*
9
10
redis-server: redis服务器
redis-cli: redis命令行客户端
redis-benchmark: redis性能测试工具
redis-check-aof: AOF文件修复工具
redis-check-rdb: RDB文件检索工具
3.2 redis配置
设置环境变量:
1
2
3
4
5
6 1echo 'export PATH=/application/redis/bin:$PATH' >>/etc/profile
2source /etc/profile
3root@ubuntu:/application# redis-server --version
4Redis server v=3.2.8 sha=00000000:0 malloc=jemalloc-4.0.3 bits=64 build=dea7c07f75756992
5
6
完成后即可启动redis服务,但启动后会出现几条警告:
1
2
3
4
5
6 1# WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
2# Server started, Redis version 3.2.8
3# WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.
4# WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command 'echo never > /sys/kernel/mm/transparent_hugepage/enabled' as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled.
5
6
如要消除这些警告可使用以下设置:
1
2
3
4
5
6 1# 允许超量使用内存
2sysctl vm.overcommit_memory=1
3echo 'vm.overcommit_memory = 1' >>/etc/sysctl.conf
4sysctl -p
5
6
1
2
3
4
5
6 1echo 511 > /proc/sys/net/core/somaxconn
2sed -i '/exit/i\echo 511 > /proc/sys/net/core/somaxconn' /etc/rc.local
3echo never > /sys/kernel/mm/transparent_hugepage/enabled
4sed -i '/exit/i\echo never > /sys/kernel/mm/transparent_hugepage/enabled' /etc/rc.local
5
6
redis.conf配置文件核心配置项:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15 1bind 127.0.0.1 # 绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip
2port 6379 # 端⼝,默认为6379
3daemonize yes
4# 是否以守护进程运⾏
5# 如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务
6# 如果以⾮守护进程运⾏,则当前终端被阻塞
7# 设置为yes表示守护进程,设置为no表示⾮守护进程
8# 推荐设置为yes
9dbfilename dump.rdb # 数据⽂件
10dir /var/lib/redis # 数据⽂件存储路径
11logfile /var/log/redis/redis-server.log # ⽇志⽂件
12database 16 # 数据库,默认有16个
13slaveof # 主从复制,类似于双机备份
14
15
3.3 redis启动
1:命令行启动
1
2
3 1redis-server /application/redis/conf/redis.conf &
2
3
2:supervisor接管redis
1
2
3 1apt install -y supervisor
2
3
在/etc/supervisor/conf.d目录下新建redis-6379.conf配置文件(文件名自取)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 1root@ubuntu:/etc/supervisor/conf.d# cat redis-6379.conf
2[program:redis]
3directory = /application/redis/
4command=/application/redis/bin/redis-server conf/redis.conf
5user=root
6autostart=true
7autorestart=true
8redirect_stderr=true
9startsecs=0
10stopsignal=KILL
11stopasgroup=true
12stdout_logfile_maxbytes=20MB
13stdout_logfile_backups=20
14stdout_logfile=/var/log/supervisor/%(program_name)s.log
15stderr_logfile=/var/log/supervisor/%(program_name)s.log
16
17
然后执行supervisor命令:
1
2
3
4 1root@ubuntu:/etc/supervisor/conf.d# supervisorctl update redis
2# 第一次刚创建配置文件,所以使用update, 以后使用supervisorctl restart|start|stop redis管理
3
4
查看日志:
1
2
3 1root@ubuntu:/etc/supervisor/conf.d# tail -f /var/log/supervisor/redis.log
2
3
3.4 使用客户端连接redis
1
2
3
4
5
6
7
8 1root@ubuntu:~# redis-cli
2127.0.0.1:6379> ping
3PONG # 连接成功,可以相互通信
4127.0.0.1:6379> select 10 # 默认连接的是0号数据库,使用select选择几号数据库
5OK
6127.0.0.1:6379[10]>
7
8
四:redis数据类型
redis是key-value的数据结构,每条数据都是⼀个键值对,键的类型是字符串
注意:键不能重复
值的类型分为五种:
- 字符串string
- 哈希hash
- 列表list
- 集合set
- 有序集合zset
4.1 string类型
字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。在Redis中字符串类型的Value最多可以容纳的数据长度是512M。
1:保存
如果设置的键不存在则为添加,如果设置的键已经存在则修改
1
2
3 1set key value
2
3
设置键为name值为ginvip的数据
1
2
3 1set name ginvip
2
3
设置键值及过期时间,以秒为单位
1
2
3 1setex key seconds value
2
3
设置键为aa值为aa过期时间为3秒的数据
1
2
3 1setex aa 3 aa
2
3
设置多个键值
1
2
3 1mset key1 value1 key2 value2 ...
2
3
设置键为’a1’值为’python’、键为’a2’值为’java’、键为’a3’值为’c’
1
2
3 1mset a1 python a2 java a3 c
2
3
追加值
1
2
3 1append key value
2
3
向键为a1中追加值’ haha’
1
2
3 1append 'a1' 'haha'
2
3
2:获取
获取:根据键获取值,如果不存在此键则返回nil
1
2
3 1get key
2
3
例5:获取键’name’的值
1
2
3 1get 'name'
2
3
根据多个键获取多个值
1
2
3 1mget key1 key2 ...
2
3
例6:获取键a1、a2、a3’的值
1
2
3 1mget a1 a2 a3
2
3
4.2 键命令
查找键,参数⽀持正则表达式:keys pattern
例1:查看所有键
1
2
3
4 1127.0.0.1:6379[10]> keys *
21) "name"
3
4
例2:查看名称中包含a的键
1
2
3 1keys 'a*'
2
3
判断键是否存在,如果存在返回1,不存在返回0
1
2
3 1exists key1
2
3
例3:判断键a1是否存在
1
2
3 1exists a1
2
3
查看键对应的value的类型
1
2
3 1type key
2
3
例4:查看键a1的值类型,为redis⽀持的五种类型中的⼀种
1
2
3 1type a1
2
3
删除键及对应的值
1
2
3 1del key1 key2 ...
2
3
例5:删除键a2、a3
1
2
3 1del a2 a3
2
3
设置过期时间,以秒为单位
如果没有指定过期时间则⼀直存在,直到使⽤DEL移除
1
2
3 1expire key seconds
2
3
例6:设置键’a1’的过期时间为3秒
1
2
3 1expire 'a1' 3
2
3
查看有效时间,以秒为单位
1
2
3 1ttl key
2
3
例7:查看键’bb’的有效时间
1
2
3 1ttl bb
2
3
4.3 hash类型
hash⽤于存储对象,对象的结构为属性、值,值的类型为string
1:增加、修改
设置单个属性
1
2
3 1hset key field value
2
3
例1:设置键 user的属性name为itheima
1
2
3 1hset user name itheima
2
3
设置多个属性
1
2
3 1hmset key field1 value1 field2 value2 ...
2
3
例2:设置键u2的属性name为bruce、属性age为11
1
2
3 1hmset u2 name bruce age 11
2
3
2:获取
获取指定键所有的属性
1
2
3 1hkeys key
2
3
例3:获取键u2的所有属性
1
2
3 1hkeys u2
2
3
获取⼀个属性的值
1
2
3 1hget key field
2
3
例4:获取键u2属性’name’的值
1
2
3 1hget u2 'name'
2
3
获取多个属性的值
1
2
3 1hmget key field1 field2 ...
2
3
例5:获取键u2属性’name’、'age的值
1
2
3 1hmget u2 name age
2
3
获取所有属性的值
1
2
3 1hvals key
2
3
例6:获取键’u2’所有属性的值
1
2
3 1hvals u2
2
3
3:删除
删除整个hash键及值,使⽤del命令;删除属性,属性对应的值会被⼀起删除
1
2
3 1hdel key field1 field2 ...
2
3
例7:删除键’u2’的属性’age’
1
2
3 1hdel u2 age
2
3
4.4 list类型
列表的元素类型为string;按照插⼊顺序排序
1:增加
在左侧插⼊数据
1
2
3 1lpush key value1 value2 ...
2
3
例1:从键为’a1’的列表左侧加⼊数据a 、 b 、c
1
2
3 1lpush a1 a b c
2
3
在右侧插⼊数据
1
2
3 1rpush key value1 value2 ...
2
3
例2:从键为’a1’的列表右侧加⼊数据0 1
1
2
3 1rpush a1 0 1
2
3
在指定元素的前或后插⼊新元素
1
2
3 1linsert key before或after 现有元素 新元素
2
3
例3:在键为’a1’的列表中元素’b’前加⼊’3’
1
2
3 1linsert a1 before b 3
2
3
2:获取
返回列表⾥指定范围内的元素
start、stop为元素的下标索引
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
1
2
3 1lrange key start stop
2
3
例4:获取键为’a1’的列表所有元素
1
2
3 1lrange a1 0 -1
2
3
设置指定索引位置的元素值
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素
1
2
3 1lset key index value
2
3
例5:修改键为’a1’的列表中下标为1的元素值为’z’
1
2
3 1lset a1 1 z
2
3
3:删除
删除指定元素
将列表中前count次出现的值为value的元素移除
1
2
3
4
5
6 1count > 0: 从头往尾移除
2count < 0: 从尾往头移除
3count = 0: 移除所有
4lrem key count value
5
6
例6.1:向列表’a2’中加⼊元素’a’、‘b’、‘a’、‘b’、‘a’、‘b’
1
2
3 1lpush a2 a b a b a b
2
3
例6.2:从’a2’列表右侧开始删除2个’b’
1
2
3 1lrem a2 -2 b
2
3
例6.3:查看列表’py12’的所有元素
1
2
3 1lrange a2 0 -1
2
3
4.5 set类型
⽆序集合
元素为string类型
元素具有唯⼀性,不重复
说明:对于集合没有修改操作
1:增加
添加元素
1
2
3 1sadd key member1 member2 ...
2
3
例1:向键’a3’的集合中添加元素’zhangsan’、‘lisi’、‘wangwu’
1
2
3 1sadd a3 zhangsan sili wangwu
2
3
2:获取
返回所有的元素
1
2
3 1smembers key
2
3
例2:获取键’a3’的集合中所有元素
1
2
3 1smembers a3
2
3
3:删除
删除指定元素
1
2
3 1srem key
2
3
例3:删除键’a3’的集合中元素’wangwu’
1
2
3 1srem a3 wangwu
2
3
4.6 zset类型
sorted set,有序集合
元素为string类型
元素具有唯⼀性,不重复
每个元素都会关联⼀个double类型的score,表示权重,通过权重将元素从⼩到⼤排序
说明:没有修改操作
1:增加
添加
1
2
3 1zadd key score1 member1 score2 member2 ...
2
3
例1:向键’a4’的集合中添加元素’lisi’、‘wangwu’、‘zhaoliu’、‘zhangsan’,权重分别为4、5、6、3
1
2
3 1zadd a4 4 lisi 5 wangwu 6 zhaoliu 3 zhangsan
2
3
2:获取
返回指定范围内的元素
start、stop为元素的下标索引
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
1
2
3 1zrange key start stop
2
3
例2:获取键’a4’的集合中所有元素
1
2
3 1zrange a4 0 -1
2
3
返回score值在min和max之间的成员
1
2
3 1zrangebyscore key min max
2
3
例3:获取键’a4’的集合中权限值在5和6之间的成员
1
2
3 1zrangebyscore a4 5 6
2
3
返回成员member的score值
1
2
3 1zscore key member
2
3
例4:获取键’a4’的集合中元素’zhangsan’的权重
1
2
3 1zscore a4 zhangsan
2
3
3:删除
删除指定元素
1
2
3 1zrem key member1 member2 ...
2
3
例5:删除集合’a4’中元素’zhangsan’
1
2
3 1zrem a4 zhangsan
2
3
删除权重在指定范围的元素
1
2
3 1zremrangebyscore key min max
2
3
例6:删除集合’a4’中权限在5、6之间的元素
1
2
3 1zremrangebyscore a4 5 6
2
3
五:redis主从
⼀个master可以拥有多个slave,⼀个slave⼜可以拥有多个slave,如此下去,形成了强⼤的多级服务器集群架构
master用来写数据,slave用来读数据,经统计:网站的读写比率是10:1
通过主从配置可以实现读写分离
master和slave都是一个redis实例(redis服务)
5.1 环境准备
172.17.2.234
unode01.ginvip.com
ubuntu16.04
master
172.17.2.235
unode02.ginvip.com
ubuntu16.04
slave
说明:redis主从配置可以是一台机器,也可以是多台
5.2 配置主redis
安装步骤同上,只是需要修改配置文件
1
2
3 1bind 172.17.2.234 # 修改为本机IP
2
3
重启redis:
1
2
3 1root@unode01:~# supervisorctl restart redis
2
3
5.3 配置从redis
配置文件修改如下项:
1
2
3
4 1bind 172.17.2.235
2slaveof 172.17.2.234 6379
3
4
启动redis:
1
2
3 1supervisorctl start redis
2
3
查看日志:
1
2
3
4
5
6
7
8
9
10
11
12
13 1root@unode02:/etc/supervisor/conf.d# tail -f /var/log/supervisor/redis.log
25592:S 26 Feb 17:35:38.891 * Connecting to MASTER 172.17.2.234:6379
35592:S 26 Feb 17:35:38.892 * MASTER <-> SLAVE sync started
45592:S 26 Feb 17:35:38.894 * Non blocking connect for SYNC fired the event.
55592:S 26 Feb 17:35:38.896 * Master replied to PING, replication can continue...
65592:S 26 Feb 17:35:38.899 * Partial resynchronization not possible (no cached master)
75592:S 26 Feb 17:35:38.901 * Full resync from master: 3595f8c7f18f7511f9c62865c20585736fa30a16:1
85592:S 26 Feb 17:35:38.966 * MASTER <-> SLAVE sync: receiving 127 bytes from master
95592:S 26 Feb 17:35:38.967 * MASTER <-> SLAVE sync: Flushing old data
105592:S 26 Feb 17:35:38.968 * MASTER <-> SLAVE sync: Loading DB in memory
115592:S 26 Feb 17:35:38.968 * MASTER <-> SLAVE sync: Finished with success
12
13
5.4 查看主从关系
1
2
3
4
5
6
7
8
9
10
11
12 1root@unode01:~# redis-cli -h 172.17.2.234 info Replication
2# Replication
3role:master
4connected_slaves:1
5slave0:ip=172.17.2.235,port=6379,state=online,offset=155,lag=1
6master_repl_offset:155
7repl_backlog_active:1
8repl_backlog_size:1048576
9repl_backlog_first_byte_offset:2
10repl_backlog_histlen:154
11
12
5.5 数据操作
1
2
3
4
5
6 1172.17.2.234:6379> set name ginvip
2OK
3172.17.2.235:6379> get name
4"ginvip"
5
6
六:redis常用操作总结
6.1 设置键值
将字符串值value关联到key。如果key已经持有其他值,set命令就覆写旧值,无视其类型。并且默认的过期时间是永久,即永远不会过期。键值对,一 一对应。
6.2 设置键值对的过期时间
6.3 hash,哈希操作
将哈希表key中的域field的值设为value。field 和value 相当于之前的键值对,key为一个大的范围,如果key不存在,一个新的哈希表被创建并进行 HSET操作。如果域 field已经存在于哈希表中,旧值将被覆盖。(可以理解为学校里的班级中的)
6.4 列表(list)操作 (可以存储重复值)
根据count 的值,删除列表中相应个数的value的元素,count的值可以是以下几种: count > 0:从表头开始向表尾搜索,移除与value相等的元素,数量为count。 count < 0:从表尾开始向表头搜索,移除与 value相等的元素,数量为count的绝对值。 count = 0:移除表中所有与value 相等的值。
6.5 set集合(集合没有重复值)的操作
6.6 事务操作
Redis事务可以一次执行多个命令,事务具有以下特征:
隔离操作:事务中的所有命令都会序列化、按顺序地执行,不会被其他命令打扰。
原子操作:事务中的命令要么全部被执行,要么全部都不执行。
6.7 发布/订阅操作
给某个频道发布消息:
1
2
3 1publish channel message
2
3
订阅某个频道的消息:
1
2
3 1subscribe channel
2
3
6.8 持久化
redis提供了两种数据备份方式,一种是RDB,另外一种是AOF,以下将详细介绍这两种备份策略
七:python与redis交互
7.1 python安装redis
1
2
3
4 1# python版本为3.7.4
2pip install redis
3
4
7.2 StrictRedis对象⽅法
1
2
3
4
5
6 1from redis import *
2sr = StrictRedis(host='localhost', port=6379, db=0, password='') # 都是默认参数
3# 简写
4# sr=StrictRedis()
5
6
注意:Python3.7版本默认写入到redis数据库中的为字节类型数据,所以取到的值都是字节类型。
decode_responses: 以字符串的形式写入Redis,为False的话写入字节类型
1
2
3
4
5 1sr = redis.StrictRedis(host='172.17.2.118', port=10009, db=0, password='BruceLee', charset='utf8', decode_responses=True)
2sr.set('mobile', '963258741')
3print(sr.get('mobile'))
4
5
Redis对象方法也是一样:
1
2
3 1sr = redis.Redis(host = '172.17.2.118', port = 10009, db = 0, password = 'BruceLee', charset='utf8', decode_responses=True)
2
3
7.3 字符串的操作
1
2
3
4
5
6
7
8
9
10
11
12
13 1 # 添加一个值进去,并且设置过期时间为60秒,如果不设置,则永远不会过期
2 sr.set('username','jack',ex=60)
3 # 获取一个值
4 sr.get('username')
5 # 删除一个值
6 sr.delete('username')
7 # 给某个值自增1
8 sr.set('count',1)
9 sr.incr('count') # 这时候read_count变为2
10 # 给某个值减少1
11 sr.decr('count') # 这时候read_count变为1
12
13
7.4 列表的操作
同字符串操作,所有方法的名称跟使用redis-cli操作是一样的:
1
2
3
4
5
6
7
8
9
10 1# 给languages这个列表往左边添加一个python
2sr.lpush('languages','python')
3
4# 给languages这个列表往左边添加一些元素
5sr.lpush('languages','php','c')
6
7# 获取languages这个列表中的所有值
8print (sr.lrange('languages',0,-1))
9
10
7.5 集合的操作
1
2
3
4
5
6
7
8
9 1# 给集合team添加一个元素
2sr.sadd('team','xiaotuo')
3# 给集合team添加一些元素
4sr.sadd('name','lee', 'van')
5
6# 获取集合中的所有元素
7print(sr.smembers('name'))
8
9
7.6 哈希(hash)的操作
1
2
3
4
5
6
7
8
9
10 1# 给website这个哈希中添加baidu
2sr.hset('website','baidu','baidu.com')
3
4# 给website这个哈希中添加google
5sr.hset('website','google','google.com')
6
7# 获取website这个哈希中的所有值
8print (sr.hgetall('website'))
9
10
7.7 事务(管道)操作
redis支持事务操作,也即一些操作只有统一完成,才能算完成。否则都执行失败,用python操作redis也是非常简单
1
2
3
4
5
6
7
8
9
10 1# 定义一个管道实例
2pip = sr.pipeline()
3# 做第一步操作,给BankA自增长1
4pip.incr('BankA')
5# 做第二步操作,给BankB自减少1
6pip.desc('BankB')
7# 执行事务
8pip.execute()
9
10
7.8 发布与订阅
1
2
3
4
5
6
7
8
9
10
11
12 1# one.py
2from redis import Redis
3cache = Redis(host = '172.17.2.118', port = 10009, db = 0, password = 'BruceLee', charset='utf8', decode_responses=True)
4ps = cache.pubsub()
5ps.subscribe('email')
6while True:
7 for item in ps.listen():
8 # print(item)
9 if item['type'] == 'message':
10 print(item['data'])
11
12
1
2
3
4
5
6
7 1# two.py
2from redis import Redis
3cache = Redis(host = '172.17.2.118', port = 10009, db = 0, password = 'BruceLee', charset='utf8', decode_responses=True)
4for x in range(5):
5 cache.publish('email', 'no way')
6
7
7.9 django-redis
1
2
3 1pip install django-redis
2
3
settings配置文件中配置redis连接信息:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 1# 使用redis作为cache backend使用配置
2CACHES = {
3 'default': {
4 'BACKEND': 'django_redis.cache.RedisCache',
5 'LOCATION': 'redis://172.17.2.118:10009/9',
6 'OPTIONS': {
7 'CLIENT_CLASS': 'django_redis.client.DefaultClient',
8 "CONNECTION_POOL_KWARGS": {"max_connections": 10, "decode_responses": True},
9 'PASSWORD': 'BruceLee',
10 }
11 }
12}
13# "CONNECTION_POOL_KWARGS": 连接池设置
14# "max_connections": 最大连接数
15# "decode_responses": 以字符串的形式写入Redis,为False的话写入字节类型
16
17
连接redis数据:
1
2
3
4 1conn = get_redis_connection('default') # default参数为上面CACHES的键
2conn.set(mobile, rand_num, ex = 5*60)
3
4