本文共 1403 字,大约阅读时间需要 4 分钟。
1.支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用
2.不仅支持key—value数据的类型,还提供list,set,zset(有序集合),hash等数据结构的存储
3.支持数据的备份(master—slave模式的数据备份)
性能高:每秒的读写速度分别是110000次(R)81000(W)
数据类型丰富:支持二进制案例的string,lists , hashs ,sets以及order sets数据类型操作
原子:redis所有的操作都是原子性的,操作要么成功执行要么失败完全不执行(只有1或者0,1代表执行成功,0表示失败完全不执行)单个操作是原子的,多个操作支持十五
丰富的特性:支持publish/subscribe,通知,key过期等等特性
1.Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。
2.Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。
string(字符串):string是redis最基本的类型,二进制安全的,可以包含任何数据,string类型一个键最大存储未521MB
set get命令
hash(哈希):redis hash一个键值对集合(key=>value),是一个string类型的field和value的映射表,hash特别适合用于存储对象
首先先使用DEL命令删除前面用过的Key,不然会报错
HSET设置值,HGET获取值
每一个Hash可以存储2^32-1个键值对(约40亿个)
list(列表):最简单的字符串列表,按照插入顺序排序,可以添加一个元素到列表的头部(左边)或者尾部(右边)
列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)
Set(集合):string类型的无序集合,通过哈希表实现的,所以添加,删除,查询的复杂度都是O(1)
sadd命令:添加一个string元素到key对应的set集合中,成功返回1,如果元素在集合中返回0,所以不存在重复添加的情况
集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)
zset(sorted set有序集合):Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但分数(score)却可以重复
Redis命令网址:
单个 Redis 命令的执行是原子性的,但 Redis 没有在事务上增加任何维持原子性的机制,所以 Redis 事务的执行并不是原子性的。事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。
转载地址:http://dkprn.baihongyu.com/