您的位置:首页 > 理论基础 > 数据结构算法

redis从入门到精通2--Redis数据结构、基本命令操作、持久化

2020-01-12 11:48 477 查看

文章目录

  • 三、Redis持久化
  • 一、redis数据结构

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

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

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

    二、redis基本操作命令

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

    1.字符串型:String

    存储:set key value
    如:set name oneStar

    获取:get key
    如:get name

    删除:del key
    如:del name

    2.哈希类型:Hash

    存储:hset key field value
    如:
    hset myhash name twoStar
    hset myhash age 18

    获取指定的field对应的值:hget key field
    如:hget myhash name

    获取所有的field和value:hgetall key
    如:hgetall myhash

    删除:hdel key field
    如:hdel myhash name

    3.列表类型:List

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

    存储
    lpush key value:将元素加入列表左表
    rpush key value:将元素加入列表右边
    如:
    lpush myList a
    lpush myList b
    rpush myList c

    获取
    lrange key start end :范围获取
    如:lrange myList 0 -1

    注:Redis Lrange 返回列表中指定区间内的元素,区间以偏移量 START 和 END 指定。 其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。 你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。

    删除
    lpop key: 删除列表最左边的元素,并将元素返回
    如:lpop myList

    rpop key: 删除列表最右边的元素,并将元素返回
    如:rpop myList

    4.集合类型:Set

    不允许重复元素

    存储:sadd key value
    如:sadd myset a

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

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

    5.有序集合类型:sortedset

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

    存储:zadd key score value
    如:zadd mysort 60 oneStar
    zadd mysort 50 twoStar
    zadd mysort 80 threeStar

    获取:zrange key start end [withscores] 获取的成员从小到大排列

    注:
    1.如果想从大到小排列 用zrevrange
    2.加上 withscores 的话可以将分值以及value都显示出来,否则只显示value

    如:zrange mysort 0 -1
    zrange mysort 0 -1 withscores

    删除:zrem key value
    如:zrem mysort oneStar

    6.通用命令

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

    三、Redis持久化

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

    Redis 持久化机制有两种:

    1.RDB持久化机制

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

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

    save 900 1
    save 300 10
    save 60 10000

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

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

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

    D:\Redis\redis-2.8.9> .\redis-server.exe .\redis.windows.conf

    2.AOF持久化机制

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

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

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

    # appendfsync always : 每一次操作都进行持久化
    appendfsync everysec : 每隔一秒进行一次持久化
    # appendfsync no     : 不进行持久化

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

    D:\Redis\redis-2.8.9> .\redis-server.exe .\redis.windows.conf
    • 点赞
    • 收藏
    • 分享
    • 文章举报
    没有钢琴的肖邦 发布了43 篇原创文章 · 获赞 16 · 访问量 3069 私信 关注
    内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
    标签: