redis持久化与数据类型

数据持久化

  • 如果没有数据持久化的需求,也完全可以关闭RDB和AOF方式,这样的话,redis就很像memcache一样,是一个纯内存数据库,数据存在内存中,读写较快,但是当系统或者服务重启后,内存里的数据就会消失。
  • redis提供了2种持久化的方式,分别是DRB和AOF方式
    (1) RDB~ 简而言之就是在不同的时间点,将redis存储的数据生成快照并存储到磁盘等介质上。关闭RDB配置如下即可:
    在这里插入图片描述
    (2)AOF~则是换个角度来实现持久化,就是将redis执行过的所有写指令记录下来,在下次redis重新启动时,只要把这些写指令从前到后再重复执行一遍,就可以实现数据恢复。内存数据保存到磁盘的3种方式
    在这里插入图片描述
  • 其实RDB和AOF2种方式也可以同时使用,在这种情况下,如果redis重启的话,则会休先采用AOF方式来进行数据恢复,这是因为AOF方式的数据恢复完整度更高。

redis数据类型

string

  • string为最简单的数据类型,与memcached一样的类型,一个key对应一个value,其支持的操作与memcached的操作类似,功能更丰富,可设置存二进制的对象。
  • 实例操作
    在这里插入图片描述
    当一个key已经被赋值后,再次set会重写该值

list

  • list是一个链表结果,主要功能是push、pop、获取一个范围的所有值等等。操作中key理解为链表的名字
  • 使用list结构,我们可以轻松地实现最新消息排行等功能(比如新浪微博的timeline)。list的另一个应用就是消息队列,可以利用list的push操作,将任务存在list中,然后工作线程再用pop操作将任务取出进行执行。PUSH与POP是一对反义词,特性“先进先出,后进后出”
  • 实例操作
    在这里插入图片描述

set

  • set是集合,和我们数学中的集合概念相似,对集合的操作有添加、删除元素,有对多个集合求交差并等操作,操作中key理解为集合的名字。比如在微博应用中,可以将一个用户所有的关注人存在一个集合,将其他粉丝存在一个集合。因为redis非常人性化的为集合提供了求交集、并集、差集等操作,那么就可以非常方便的实现如共同关注、共同喜好、二度好友等功能,对上面的所以集合操作,你还可以使用不同的命令选择将结果返回给客户端还是存集到一个新的集合中。
  • 实例操作
    在这里插入图片描述
    SADD /添加元素
    SMEMBERS /查看元素
    SINTER /求交集
    SUNION /求并集
    SDIFF /求差集
    SREM /删除元素

sort set

  • sort set是有序集合,它比set多了一个权重参数score,使得集合中的元素能够按score进行有序排列,比如一个存储全班同学成绩的sorted sets,其集合value可以是同学的学号,而score就可以是其考试得分,这样在数据插入集合的时候,就已经进行了天然的排序。
  • 实例操作
    在这里插入图片描述
    ZRANGE /正序
    ZREVRANGE /反序

hash

  • 在memcached中,我们经常将一些结构化的信息打包成hashmap,在客户端序列化后存储为一个字符串的值(一般是JSON格式),比如用户的昵称、年龄、性别、积分等
  • 实例操作
    在这里插入图片描述
    HSET /增加一个或多个子元素
    HGET /获取hash子元素的值
    HGETALL /获取hash的全部元素
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值