1.概念
Redis是一个开源,高级的键值存储和一个适用的解决方案,用于构建高性能,可扩展的Web应用程序。是由意大利人Salvatore Sanfilippo(网名:antirez)开发的一款内存高速缓存数据库。Redis全称为:Remote Dictionary Server(远程数据服务),该软件使用C语言编写,Redis是一个key-value存储系统,它支持丰富的数据类型,如:string、list、set、zset(sorted set)、hash。
2.主要特点
这里抄一下刘丹同学的总结:
1. 速度快:使用标准C写,所有数据都在内存中完成,读写速度分别达到10万/20万
2. 持久化:对数据的更新采用Copy-on-write技术,可以异步地保存到磁盘上,主要有两种策略,一是根据时间,更新次数的快照(save 300 10 )二是基于语句追加方式(Append-only file,aof)
3. 自动操作:对不同数据类型的操作都是自动的,很安全
4. 快速的主--从复制,官方提供了一个数据,Slave在21秒即完成了对Amazon网站10G key set的复制。
5. Sharding技术: 很容易将数据分布到多个Redis实例中,数据库的扩展是个永恒的话题,在关系型数据库中,主要是以添加硬件、以分区为主要技术形式的纵向扩展解决了很多的应用场景,但随着web2.0、移动互联网、云计算等应用的兴起,这种扩展模式已经不太适合了,所以近年来,像采用主从配置、数据库复制形式的,Sharding这种技术把负载分布到多个特理节点上去的横向扩展方式用处越来越多。
Redis:既有临时性又有永久性,先把数据保存在内存中,满足特定条件时将数据写入硬盘,这样既保证了速度,又可以通过写入硬盘保证了数据的永久性。总结来说:
- 同时在内存和硬盘上保存数据
- 可以进行非常快速的保存和读取处理
- 保存在硬盘上的数据不会消失(可以恢复)
- 适合于处理数组类型的数据
3.优点:
- 异常快 - Redis非常快,每秒可执行大约
110000
次的设置(SET
)操作,每秒大约可执行81000
次的读取/获取(GET
)操作。 - 支持丰富的数据类型 - Redis支持开发人员常用的大多数数据类型,例如列表,集合,排序集和散列等等。这使得Redis很容易被用来解决各种问题,因为我们知道哪些问题可以更好使用地哪些数据类型来处理解决。
- 操作具有原子性 - 所有Redis操作都是原子操作,这确保如果两个客户端并发访问,Redis服务器能接收更新的值。
- 多实用工具 - Redis是一个多实用工具,可用于多种用例,如:缓存,消息队列(Redis本地支持发布/订阅),应用程序中的任何短期数据,例如,web应用程序中的会话,网页命中计数等。
Redis是键值数据库系统的不同进化路线,它的值可以包含更复杂的数据类型,可在这些数据类型上定义原子操作。
Redis是一个内存数据库,但在磁盘数据库上是持久的,因此它代表了一个不同的权衡,在这种情况下,在不能大于存储器(内存)的数据集的限制下实现非常高的写和读速度。
内存数据库的另一个优点是,它与磁盘上的相同数据结构相比,复杂数据结构在内存中存储表示更容易操作。 因此,Redis可以做很少的内部复杂性。
4.安装与启动
这个网上很好找到:
http://www.yiibai.com/redis/redis_quick_guide.html
5.Redis数据类型
Redis支持五种数据类型,分别为:
a:字符串
Redis中的字符串是一个字节序列。Redis中的字符串是二进制安全的,这意味着它们的长度不由任何特殊的终止字符决定。因此,可以在一个字符串中存储高达512
兆字节的任何内容。
redis
127.0
.
0.1
:
6379
> set name
"yiibai.com"
OK
redis
127.0
.
0.1
:
6379
> get name
"yiibai.com"
|
在上面的示例中,set
和get
是Redis命令,name
是Redis中使用的键,yiibai.com
是存储在Redis中的字符串的值。
注 - Redis命令不区分大小写,如
SET
,Set
和set
都是同一个命令。字符串值的最大长度为 512MB。
b:散列/哈希(类似与map)
Redis散列/哈希(Hashes)是键值对的集合。Redis散列/哈希是字符串字段和字符串值之间的映射。因此,它们用于表示对象。
redis
127.0
.
0.1
:
6379
> HMSET ukey username
"yiibai"
password
"passswd123"
points
200
|
在上述示例中,散列/哈希数据类型用于存储包含用户的基本信息的用户对象。这里HMSET
,HGETALL
是Redis的命令,而ukey
是键的名称。
每个散列/哈希可以存储多达2^32 - 1
个健-值对(超过40
亿个)。
c:列表(key可以重复)
Redis列表只是字符串列表,按插入顺序排序。您可以向Redis列表的头部或尾部添加元素。
redis
127.0
.
0.1
:
6379
> lpush alist redis
(integer)
1
redis
127.0
.
0.1
:
6379
> lpush alist mongodb
(integer)
2
redis
127.0
.
0.1
:
6379
> lpush alist sqlite
(integer)
3
redis
127.0
.
0.1
:
6379
> lrange alist
0
10
1
)
"sqlite"
2
)
"mongodb"
3
)
"redis"
|
列表的最大长度为2^32 - 1
个元素(4294967295
,每个列表可容纳超过40
亿个元素)。
d:集合(类似与set,key不可以重复)
Redis集合是字符串的无序集合。在Redis中,您可以添加,删除和测试成员存在的时间O(1)复杂性。
redis
127.0
.
0.1
:
6379
> sadd yiibailist redis
(integer)
1
redis
127.0
.
0.1
:
6379
> sadd yiibailist mongodb
(integer)
1
redis
127.0
.
0.1
:
6379
> sadd yiibailist sqlite
(integer)
1
redis
127.0
.
0.1
:
6379
> sadd yiibailist sqlite
(integer)
0
redis
127.0
.
0.1
:
6379
> smembers yiibailist
1
)
"sqlite"
2
)
"mongodb"
3
)
"redis"
|
tag:在重复添加的情况下,只会添加一次。
e可排序集合
Redis可排序集合类似于Redis集合,是不重复的字符集合。 不同之处在于,排序集合的每个成员都与分数相关联,这个分数用于按最小分数到最大分数来排序的排序集合。虽然成员是唯一的,但分数值可以重复。
redis
127.0
.
0.1
:
6379
> zadd yiibaiset
0
redis
(integer)
1
redis
127.0
.
0.1
:
6379
> zadd yiibaiset
0
mongodb
(integer)
1
redis
127.0
.
0.1
:
6379
> zadd yiibaiset
1
sqlite
(integer)
1
redis
127.0
.
0.1
:
6379
> zadd yiibaiset
1
sqlite
(integer)
0
redis
127.0
.
0.1
:
6379
> ZRANGEBYSCORE yiibaiset
0
1000
1
)
"mongodb"
2
)
"redis"
3
)
"sqlite"
|
因为 ‘sqlite
‘ 的排序值是 1 ,其它两个元素的排序值是 0 ,所以 ‘sqlite
‘ 排在最后一个位置上。
其他Redis命令:
http://www.redis.net.cn/order/