Redis简介
Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库。
Redis 与其他 key - value 缓存产品有以下三个特点:
- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
- Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
- Redis支持数据的备份,即master-slave模式的数据备份。
Redis 优势
- 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
- 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
- 原子 – Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。
- 单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。
- 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
Redis 数据类型
Redis支持五种数据类型:
string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
String(字符串)
string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。
string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。
string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。
Hash(哈希)
Redis hash 是一个键值(key=>value)对集合。
Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。
List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
Set(集合)
Redis 的 Set 是 string 类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
zset(sorted set:有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
Python操作redis
安装redis模块
在python中,要操作redis,目前主要是通过一个python-redis模块来实现
pip install redis
创建连接
导入redis模块,实例化一个Redis类对象
参数说明:
host:Redis服务器地址
port:Redis端口号,默认端口号6379
db:库(如下图)
password:Redis密码
decode_responses:decode_response=True 返回字符串类型,不加返回字节类型
import redis
redis_info = {
"host":"xxx.xxx.xxx.xxx",
"password":"xxxxxx",
"port":6379,
"db":0
}
r = redis.Redis(**redis_info,decode_responses=True)
操作string类型
增加数据
设置指定 key 的值
Redis SET 命令用于设置给定 key 的值。
如果 key 已经存储其他值, SET 就覆写旧值,且无视类型。
基本语法:SET KEY_NAME VALUE
r.set("redistest", '小爱同学')
指定key的时效时间
r.set("redistest", '小爱同学',30)
查看key的剩余过期时间
以秒为单位返回 key 的剩余过期时间
print(r.get("redistest"))
print(r.ttl("redistest")) #以秒为单位返回 key 的剩余过期时间
控制台输出:
小爱同学
21
获取数据
获取指定 key 的值。
Redis get 命令用于获取指定 key 的值。
如果 key 不存在,返回 None。
如果key 储存的值不是字符串类型,返回一个错误。
print(r.get("redistest")) #获取指定 key 的值
print(r.type("redistest")) ##查看key的value类型
控制台输出:
小爱同学
string
删除数据
删除指定key的值,删除成功返回1
如果key不存在,也不会报错,返回0
print(r.delete("redistest")) #删除指定key的值
print(r.delete("redistest")) #对一个key 进行两次删除
控制台输出:
1
0
判断key是否存在
看key是否存在,存在返回1,不存在返回0
print(r.exists("redistest"))
print(r.exists("redis"))
控制台输出:
1 # key存在
0 # key不存在
操作hash类型
增加数据
r.hset("students","xiaoming","{'age':18,'sex':'f'}")
r.hset("students","xiaohong","{'age':20,'sex':'m'}")
print(r.type("students")) # 控制台 打印 hash
指定key的失效时间
r.expire("students",30) # 对指定的key设置失效时间
批量添加数据
stus = {"xiaoming": "18", "xiaohong": "25","xiaolan": '{"age": 23, "sex": "f"}'}
r.hset("students", mapping=stus) #批量添加数据
print(r.hgetall("students"))
控制台输出:
{'xiaoming': '18', 'xiaohong': '25', 'xiaolan': '{"age": 23, "sex": "f"}'}
获取数据
print(r.hget("students","xiaoming")) #获取"students" key下的"xiaoming"的值
print(r.hgetall("students")) #获取所有key的值
控制台输出:
18
{'xiaoming': '18', 'xiaohong': '25', 'xiaolan': '{"age": 23, "sex": "f"}'}
获取所有的key、value
print(r.hkeys("students")) # 获取hash下面的所有小key
print(r.hvals("students")) # 获取hash下面的所有value
控制台输出:
['xiaoming', 'xiaohong', 'xiaolan']
['18', '25', '{"age": 23, "sex": "f"}']
获取当前数据库所有key
print(r.keys()) #获取当前数据库里面所有的key
控制台输出:
['students', 'redistest']
判断小key是否存在
print(r.hexists("students","xiaoming"))
print(r.hexists("students","小李"))
控制台输出:
True
False
删除数据
r.hdel("students","xiaohong") #删除指定的小key
r.delete("students") #删除整个hash