Redis介绍
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库。Redis的外围由一个键、值映射的字典构成
与其他非关系型数据库主要不同在于:Redis中值的类型,不仅限于字符串
redis提供五种数据类型:string,hash,list,set及zset(sorted set)
Redis性能极高,读的速度是110000次/s,写的速度是81000次/s
支持 publish/subscribe, 通知, key 过期等等特性。
redis使用了两种文件格式:全量数据和增量请求。
Redis数据类型
- String(字符串)
- String是Redis最基本的数据类型,一个key对应一个value
- string是二进制安全的,可以包含任何数据(图片、序列化对象…)
- string一个key最大可以存储512MB
redis 127.0.0.1:6379> SET name "runoob"
OK
redis 127.0.0.1:6379> GET name
"runoob"
- Hash
- hash是键值对的集合,即一个key对应value集合(school=>student “小明” teacher “老王”)
- hash比较适合存储对象
- 每个 hash 可以存储 232−1 2 32 − 1 键值对(40多亿)
redis> HMSET myhash field1 "Hello" field2 "World"
"OK"
redis> HGET myhash field1
"Hello"
redis> HGET myhash field2
"World"
- List(列表)
- 即简单的string列表,可以在头部插入,同时也可以在尾部插入
- 每个 list可以存储 232−1 2 32 − 1 键值对(40多亿)
redis 127.0.0.1:6379> lpush runoob redis
(integer) 1
redis 127.0.0.1:6379> lpush runoob mongodb
(integer) 2
redis 127.0.0.1:6379> lpush runoob rabitmq
(integer) 3
redis 127.0.0.1:6379> lrange runoob 0 10
1) "rabitmq"
2) "mongodb"
3) "redis"
- Set(集合)
- Redis的Set是string类型的无序集合
- 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1) O ( 1 )
- Set集合添加一个 string 元素到 key 对应的 set 集合中,成功返回1,如果元素已经在集合中返回 0,如果 key 对应的 set 不存在则返回错误
- 每个Set可以存储 232−1 2 32 − 1 键值对(40多亿)
redis 127.0.0.1:6379> sadd runoob redis
(integer) 1
redis 127.0.0.1:6379> sadd runoob mongodb
(integer) 1
redis 127.0.0.1:6379> sadd runoob rabitmq
(integer) 1
redis 127.0.0.1:6379> sadd runoob rabitmq
(integer) 0
redis 127.0.0.1:6379> smembers runoob
1) "redis"
2) "rabitmq"
3) "mongodb"
- zset(sorted set:有序集合)
- Redis zset 是string类型元素的集合,且不允许重复的成员
- 不同的是每个元素都会关联一个double类型的分数
- redis通过分数来为集合中的成员进行从小到大的排序
- zset的成员是唯一的,但分数(score)却可以重复
- 添加元素到集合,元素在集合中存在则更新对应score
redis 127.0.0.1:6379> zadd runoob 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 rabitmq
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 rabitmq
(integer) 0
redis 127.0.0.1:6379> > ZRANGEBYSCORE runoob 0 1000
1) "mongodb"
2) "rabitmq"
3) "redis"
下篇文章会根据Redis的数据类型分门别类的去详细介绍Redis的特性及使用方法等