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

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

作者: 丛鹏 | 来源:发表于2019-12-30 20:59 被阅读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服务器,并指定配置文件名称,便可以进行持久化了

相关文章

  • redis基础

    redis概念下载安装命令操作数据结构持久化操作使用Java客户端操作redis Redis 概念: redis是...

  • redis

    今日内容 redis 概念 下载安装 命令操作 数据结构 持久化操作 使用Java客户端操作redis Redis...

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

    一、Redis 数据结构 要想使用 Redis 进行数据存储,首先需要了解 Redis 的数据结构,redis存储...

  • 【Redis】Redis中5种基础数据结构以及相应的命令行和Py

    本文主要介绍了Redis中5种基本的数据结构,以及相应的数据操作命令。 Redis基本数据结构 Redis是键值对...

  • redis在Centos7上介绍和安装

    redis一般提供缓存服务 redis基本操作 解释 命令 安装 源码编译安装 启动 ...

  • PHP问题汇总

    php异常级别 redis持久化机制 redis缓存雪崩和缓存穿透 其他redis问题 redis地理位置 mys...

  • redis与tair

    1. Redis(缓存/持久化) 适用 需要使用复杂数据结构(string, hashtable, list , ...

  • Redis-14-Jedis的基本使用

    述 前面的文章中介绍了一些reids的基本命令,数据结构,持久化方式,还有主从集群等等,我们操作redis的数据的...

  • Redis

    如果java项目要使用redis的时候,需要启动redis的服务的 概念 下载安装 命令操作 持久化操作

  • Redis介绍使用及进阶

    目录: 一、介绍 二、缓存问题 三、Redis内存滥用 四、键命名规范 五、Redis使用场景 六、持久化操作 七...

网友评论

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

      本文链接:https://www.haomeiwen.com/subject/psfvoctx.html