Redis笔记1-Redis介绍及数据类型使用场景

Redis介绍:
C语言开发、单线程操作、高性能、键值对、可持久化的数据库。
Redis采用redisObject结构来统一五种数据类型,redisObject是五种类型的父类,可以在函数间传递时隐藏具体的类型信息。这样所有的数据类型就都可以以相同的形式在函数间传递而不用使用特定的类型结构。同时,为了识别不同的数据类型,redisObjec中定义了type和encoding字段对不同的数据类型加以区别。
持久化文件:dump.rdb
Redis持久化机制:
1:RDB:默认方式,不需要配置。间隔一段时间,检测key发生变化,然后持久化数据,对服务器性能影响小,推荐使用
save 900 1 -- 900秒后,如果有1个命令操作,就持久化
save 300 10 -- 300秒后,如果有10个命令操作,就持久化
save 10 1000 -- 10秒后,如果有1000个命令操作,就持久化
2:AOF:每一次命令操作后,持久化数据

数据类型:

String类型:
value可以是String类型,也可以是数字类型;String类型在redis内部存储默认就是一个字符串,当遇到incr、decr等操作就会转换成数值型进行计算,此时redisObject的encoding值为int。

Hash类型:
Hash是最接近关系型数据库结构的数据类型,可以将数据库中的一条记录或一个对象转换为hashmap存放在redis中
Hash是一个string类型的field、value的映射表。适合存储对象。将一个对象存储在hash类型中会占用更少的内存,并且可以更方便的存取整个对象。Hash结构还可以使你像在数据库中Update一个属性一样只修改某一项属性值。

List类型:
列表,数据结构是双向链表,可以存储列表结构的数据,List另一个应用就是消息队列。Redis还提供了操作Lists中某一段的api,你可以直接查询,删除Lists中某一段的元素。

set类型:
集合,和List的区别是Set元素无序且不可重复;可以获取集合间交际、并集、差集、补集等操作
Set是Hash Table,相同的对象内容只能在Set中存在一次,后面在添加的对象内容会覆盖已经存在Set中的对象内容
比如在微博应用中,可以将一个用户所有的关注人存在一个集合中,将其所有粉丝存在一个集合。Redis还为集合提供了求交集、并集、差集等操作,可以非常方便的实现如共同关注、共同喜好、二度好友等功能,对上面的所有集合操作,你还可以使用不同的命令选择将结果返回给客户端还是存集到一个新的集合中。

 

Zset类型:
有序集合,在set的基础上增加一个顺序属性,比如一个存储全班同学成绩的Sorted Sets,其集合value可以是同学的学号,而score就可以是其考试得分,这样在数据插入集合的时候,就已经进行了天然的排序。
场景:排行榜、处理过期项目:如果有新数据添加时,我们把它加到有序集合中,用时间做排序。开一个服务定时查询,取前十项,时间过期就删除数据。

 

 

Pub/Sub
Pub/Sub 从字面上理解就是发布(Publish)与订阅(Subscribe),在Redis中,你可以设定对某一个key值进行消息发布及消息订阅,当一个key值上进行了消息发布后,所有订阅它的客户端都会收到相应的消息。这一功能最明显的用法就是用作实时消息系统,比如普通的即时聊天,群聊等功能。

 

 

Transactions
谁说NoSQL都不支持事务,虽然Redis的Transactions提供的并不是严格的ACID的事务(比如一串用EXEC提交执行的命令,在执行中服务器宕机,那么会有一部分命令执行了,剩下的没执行),但是这个Transactions还是提供了基本的命令打包执行的功能(在服务器不出问题的情况下,可以保证一连串的命令是顺序在一起执行的,中间有会有其它客户端命令插进来执行)。Redis还提供了一个Watch功能,你可以对一个key进行Watch,然后再执行Transactions,在这过程中,如果这个Watched的值进行了修改,那么这个Transactions会发现并拒绝执行。

你可能感兴趣的:(Redis笔记1-Redis介绍及数据类型使用场景)