三、Redis持久化

1、RDB 持久化机制

2、 AOF 持久化机制


一、Redis 数据结构

============

要想使用 Redis 进行数据存储,首先需要了解 Redis 的数据结构,redis存储的是:key,value格式的数据,其中key都是字符串,value有5种不同的数据结构:

  1. 字符串类型 string
  2. 哈希类型 hash : map格式
  3. 列表类型 list : linkedlist格式。支持重复元素
  4. 集合类型 set  : 不允许重复元素
  5. 有序集合类型 sortedset:不允许重复元素,且元素有顺序

这五种数据结构存储方式可见下表:

centos 删除所有的redis key_redis

二、Redis 基本命令操作

===============

针对以上五种不同的数据结构,Redis 有相应的命令来进行操作,可以达到对数据的存储、获取和删除

1、字符串型:string


  • 存储:set key value
  • eg:set name oneStar
  • 获取:get key
  • eg:get name
  • 删除:del key
  • eg:del name

centos 删除所有的redis key_缓存_02

2、哈希类型:hash


  • 存储:hset key field value
  • eg:hset myhash name twoStar

hset myhash age 18

  • 获取指定的field对应的值:hget key field
  • 获取所有的field和value:hgetall key
  • eg:hget myhash name
  • eg:hgetall myhash
  • 删除:hdel key field
  • eg:hdel myhash name

centos 删除所有的redis key_Redis_03

3、列表类型:list


可以添加一个元素到列表的头部(左边)或者尾部(右边)

  • 存储
  • lpush key value:将元素加入列表左表
  • rpush key value:将元素加入列表右边
  • eg:lpush myList a

lpush myList b

rpush myList c

  • 获取:lrange key start end :范围获取
  • eg:lrange myList 0 -1
  • 删除
  • lpop key: 删除列表最左边的元素,并将元素返回
  • eg:lpop myList
  • rpop key: 删除列表最右边的元素,并将元素返回
  • eg:rpop

centos 删除所有的redis key_数据结构_04

4、集合类型:set


不允许重复元素

  • 存储:sadd key value
  • eg:sadd myset a
  • 获取set集合中所有元素:smembers key
  • eg:smembers myset
  • 删除set集合中的某个元素:srem key value
  • eg:srem myset a

centos 删除所有的redis key_Redis_05

5、有序集合类型:sortedset


不允许重复元素,且元素有顺序.每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

  • 存储:zadd key score value
  • eg:zadd mysort 60 oneStar

zadd mysort 50 twoStar

zadd mysort 80 threeStar

  • 获取:zrange key start end [withscores]
  • eg1:zrange mysort 0 -1
  • eg2:zrange mysort 0 -1 withscores
  • 删除:zrem key value
  • eg:zrem mysort oneStar

centos 删除所有的redis key_持久化_06

6、通用命令


  • keys * : 查询所有的键
  • eg:keys *
  • type key : 获取键对应的value的类型
  • eg:type myhash
  • del key:删除指定的key value
  • eg:del myhash

centos 删除所有的redis key_数据结构_07

三、Redis持久化

==========

redis是一个内存数据库,当redis服务器重启,获取电脑重启,数据会丢失,为了解决这个问题,我们可以将 redis 内存中的数据持久化保存到硬盘的文件中。

Redis 持久化机制有两种:

1、RDB 持久化机制


RDB 持久化机制是默认的方式,不需要进行配置,默认就使用这种机制,在一定的间隔时间中,检测key的变化情况,然后持久化数据,对性能影响不大。