【Redis缓存】- Redis数据结构、基本命令操作、持久化

2019-12-30  本文已影响0人  丛鹏

一、Redis 数据结构

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

字符串类型 string

哈希类型 hash : map格式  

列表类型 list : linkedlist格式。支持重复元素

集合类型 set  : 不允许重复元素

有序集合类型 sortedset:不允许重复元素,且元素有顺序

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

 二、Redis 基本命令操作

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

1、字符串型:string

存储:set key value

eg:set name oneStar

获取:get key

eg:get name

删除:del key

eg:del name

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

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

4、集合类型:set

不允许重复元素

存储:sadd key value

eg:sadd myset a

获取set集合中所有元素:smembers key

eg:smembers myset

删除set集合中的某个元素:srem key value

eg:srem myset a

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

6、通用命令

keys * : 查询所有的键

eg:keys *

type key : 获取键对应的value的类型

eg:type myhash

del key:删除指定的key value

eg:del myhash

三、Redis持久化

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

Redis 持久化机制有两种:

1、RDB 持久化机制

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

【1】RDB 持久化机制,是根据 Redis 安装目录下的 redis.windwos.conf 文件中配置内容决定的:

save 900 1:如果 15 分钟后最少有一个 key 被改变就持久化一次

save 300 10:如果 5 分钟后最少有 10 个 key 被改变就持久化一次

save 60  10000:如果 1 分钟后最少有 10000 个 key 被改变就持久化一次

可以通过改变这个配置来指定自己想要的持久化时间和次数

【2】重新在命令行启动redis服务器,并指定配置文件名称,便可以进行持久化了

2、 AOF 持久化机制

AOF 持久化机制是使用日志记录的方式,可以记录每一条命令的操作,可以每一次命令操作后,持久化数据,执行一条语句就进行一次持久化,对性能的影响比较大。

【1】开启 AOF 持久化机制

编辑 redis.windwos.conf 文件,找到 appendonly no,将 no 改为 yes,即表示开启 AOF 持久化机制

在 redis.windwos.conf 文件中,可以找到如下信息:

# appendfsync always : 每一次操作都进行持久化

appendfsync everysec : 每隔一秒进行一次持久化

# appendfsync no     : 不进行持久化

【2】重新在命令行启动redis服务器,并指定配置文件名称,便可以进行持久化了

上一篇 下一篇

猜你喜欢

热点阅读