美文网首页
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