美文网首页
Redis 入门

Redis 入门

作者: 一路摇到顶 | 来源:发表于2017-08-16 22:33 被阅读23次

    Redis是一个key-value存储系统。(Key-Value Store)

    • Key-Value Store的可拓展性是最大的优势,一方面可以支持极大的数据的存储,采用分布式架构只要有更多的机器,就能保证存储更多的数据,另一方面支持高并发查询
      1. 只支持基本操作 SET GET
      2. 分布式,多机器同时存储数据和状态,彼此保持数据一致。
      3. 数据一致性,有的节点都是同步更新,不用担心数据不一致的结果。
      4. 冗余,节点保持有相同的数据,整个系统的存储能力取决于单台机器。
      5. 容错。少数node出现异常,重启,宕机,断网等不会影响整个系统的运行。
      6. 高可靠性。冗余与容错保证了数据系统的可靠性

    Redis简介

    1. 数据类型
      List,Sets, Sorted Sets,Hashes
    2. 持久化 使用快照,将内存数据写入磁盘。使用类似Mysql的日志方式记录每次更新。前者速度快,可能会丢失数据,后者相反。
    3. 主从同步 支持数据同步到多台从库上
    4. 基于内存,比基于磁盘的数据库 快很多。

    Redis配置

    捕获2.PNG 捕获3.PNG 捕获4.PNG 捕获5.PNG

    Redis操作

    String 类型

    • 二进制安全,可以保持任何数据,做大限制为1G。
    1. set [key] [value] 设置值
    2. setnx [key] [value] 设置新值 如果该key已经存在,返回0. nx=not exist
    3. setex [key] [expire time] [value] 设置key,并设置过期时间。
    4. setrange [key] [offset] [newValue] 设定子字符串,替换offset后的字符串
    5. mset [key] [value] [key] [value] [key] [value]... 设置多个值
    6. msetnx [key] [value] [key] [value] [key] [value]... 设置多个没有存在的key的值
    7. get [key] 获取值
    8. getset [key] [newVlaue] 设置新值,返回旧值
    9. getrange [key] [start] [end] 获取子字符串。从左开始下标从0,右边开始 下标从-1
    10. mget [key1] [key2] [key3]
    11. incr [key] 累加
    12. incrby [key] [值] 累加指定值
    13. decr [key] 减减
    14. decrby [key][值] 减指定值
    15. append [key][value] +
    16. strlen [key] 长度

    hashes

    • string类型的field和value的映射表,数据少的时候zipmap,多的使用正常的hash
    1. hset [key][field][value]
    2. hsetnx [key][field][value]
    3. hmset [key][field][value][field][value]...
    4. hget [key][field]
    5. hmget [key][field][field]
    6. hincrby [key][field][value]
    7. hexists [key][field]
    8. hlen [key] fileld count
    9. hdel [key] [field]
    10. hkeys [key] 该对象的所有field
    11. hvals [key] 该对象所有的值
    12. hgetall [key] 获取所有的field和value

    list 链表结构

    1. lpush [key][value]头部添加
    2. rpush [key][value] 尾部添加
    3. linsert [key] before [value] [newValue]
    4. lset [key] [index] [value] 设定指定的指定值
    5. lrem [key] [count] [value] 删除count个value count>0 从头开始,count<0 从尾巴开始,count=0 全部删除
    6. ltrim [key] 【start】【end】保留指定范围的数据
    7. lpop 删除头部 并返回
    8. rpop 删除尾部 并返回
    9. rpoplpush 【key】[key] 删除第一个的尾部,并添加到新的头部,返回删除的那个值
    10. lindex [key][index] 返回指定index的值
    11. llen [key] 长度

    sets类型

    set集合类型,除了对集合普通的增加删除,同时支持对多个集合的交并差计算,key为集合的名字。

    1. sadd【key】【value】 (重复值添加无效)
    2. srem 【key】【value】 删除 集合中的value值
    3. spop[key] 随机删除一个值,并返回
    4. smembers [key] 显示集合的值
    5. sdiff 【key1】【key2】 差集 key1+key2-key2
    6. sdiffstore [saveKey][key1][key2][key3] 与key1的差集,保存为saveKey
    7. sinter 【key1】【key2】交集
    8. sinterstore [saveKey][key1][key2][key3] 交集并保存为saveKey
    9. sunion [key1][key2]并集
    10. sunionstore [saveKey][key1][key2] 并集并保存为saveKey
    11. smove [key1] [key2][value] 把value从key1移动到key2
    12. scard 【key】 set.size()
    13. sismember [key] [value] value是不是属于该集合
    14. srandmember [key] 随机返回一个元素,但是不删除该元素

    sorted sets 有序集合(zset)

    set的加强版本,增加了顺序属性。zset是一个String类型的元素集合,但是包含了一个score的值,用于排序。

    1. zadd 【key】【score】【value】 添加,多次添加同一个value,将以最后一次为准
      1.zrem [key] [value] 删除value
    2. zincrby[key][addValue][value] 如果value不存在进行添加score为addvalue。否则value的score=score+addValue
      1.zrank 【key】【value】 按照从小大到 方,返回value 的下标
      1.zrevrank [key][value] 按照从大到小返回value的下标
      1.zrevrange [key][startIndex][endIndex] withscores 从大到小返回值,startIndex到endIndex的值
    3. zrange [key] [startIndex][endIndex] withscores 从小到大返回startIndex到endIndex的值
    4. zrangebyscore [key][minScore][maxScore] withscores 返回集合中score在范围内的元素
    5. zcount [key][minScore][maxScore] key中score在指定范围中的值。
    6. zcard [key] 返回集合中的元素
    7. zscore 【key】[value] 该value的score
    8. zremrangebyrank [key] [rankStart][randEnd] 删除集合中,在指定区间的元素。
    9. zremrangebyscore 删除集合中score在给定区间的值

    Redis常用命令

    键值相关

    1. keys 【pattern】 满足pattern的所有可以
    2. exists [key]是否存在key
    3. del 删除一个key
    4. expire key [time(秒)] 给一个key设置过期时间
    5. move key 【db no】 将key移动到别的数据库(0-15)
    6. persist [key] 移除该key 的过期时间
    7. ttl 【key】 该key的剩余时间 -1 为没有过期时间
    8. randomkey 随机返回一个key
    9. rename [key][newKey] 设置新的age
    10. type [key] 该key的类型

    服务器相关命令

    1. ping redis连接是否存在
    2. echo '1111' 打印1111
    3. select [0-15] 选择数据库
    4. quit 退出连接
    5. dbsize 当前数据库中的数量
    6. info redis服务器信息
    7. monitor 实时转存收到的请求
    8. config get [key] 获取配置信息
    9. flushdb 删除当前选择的数据库里面的所有key
    10. flushall 删除所有数据库的值

    相关文章

      网友评论

          本文标题:Redis 入门

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