Redis是一个key-value存储系统。(Key-Value Store)
- Key-Value Store的可拓展性是最大的优势,一方面可以支持极大的数据的存储,采用分布式架构只要有更多的机器,就能保证存储更多的数据,另一方面支持高并发查询
- 只支持基本操作 SET GET
- 分布式,多机器同时存储数据和状态,彼此保持数据一致。
- 数据一致性,有的节点都是同步更新,不用担心数据不一致的结果。
- 冗余,节点保持有相同的数据,整个系统的存储能力取决于单台机器。
- 容错。少数node出现异常,重启,宕机,断网等不会影响整个系统的运行。
- 高可靠性。冗余与容错保证了数据系统的可靠性
Redis简介
- 数据类型
List,Sets, Sorted Sets,Hashes - 持久化 使用快照,将内存数据写入磁盘。使用类似Mysql的日志方式记录每次更新。前者速度快,可能会丢失数据,后者相反。
- 主从同步 支持数据同步到多台从库上
- 基于内存,比基于磁盘的数据库 快很多。
Redis配置
捕获2.PNG 捕获3.PNG 捕获4.PNG 捕获5.PNGRedis操作
String 类型
- 二进制安全,可以保持任何数据,做大限制为1G。
- set [key] [value] 设置值
- setnx [key] [value] 设置新值 如果该key已经存在,返回0. nx=not exist
- setex [key] [expire time] [value] 设置key,并设置过期时间。
- setrange [key] [offset] [newValue] 设定子字符串,替换offset后的字符串
- mset [key] [value] [key] [value] [key] [value]... 设置多个值
- msetnx [key] [value] [key] [value] [key] [value]... 设置多个没有存在的key的值
- get [key] 获取值
- getset [key] [newVlaue] 设置新值,返回旧值
- getrange [key] [start] [end] 获取子字符串。从左开始下标从0,右边开始 下标从-1
- mget [key1] [key2] [key3]
- incr [key] 累加
- incrby [key] [值] 累加指定值
- decr [key] 减减
- decrby [key][值] 减指定值
- append [key][value] +
- strlen [key] 长度
hashes
- string类型的field和value的映射表,数据少的时候zipmap,多的使用正常的hash
- hset [key][field][value]
- hsetnx [key][field][value]
- hmset [key][field][value][field][value]...
- hget [key][field]
- hmget [key][field][field]
- hincrby [key][field][value]
- hexists [key][field]
- hlen [key] fileld count
- hdel [key] [field]
- hkeys [key] 该对象的所有field
- hvals [key] 该对象所有的值
- hgetall [key] 获取所有的field和value
list 链表结构
- lpush [key][value]头部添加
- rpush [key][value] 尾部添加
- linsert [key] before [value] [newValue]
- lset [key] [index] [value] 设定指定的指定值
- lrem [key] [count] [value] 删除count个value count>0 从头开始,count<0 从尾巴开始,count=0 全部删除
- ltrim [key] 【start】【end】保留指定范围的数据
- lpop 删除头部 并返回
- rpop 删除尾部 并返回
- rpoplpush 【key】[key] 删除第一个的尾部,并添加到新的头部,返回删除的那个值
- lindex [key][index] 返回指定index的值
- llen [key] 长度
sets类型
set集合类型,除了对集合普通的增加删除,同时支持对多个集合的交并差计算,key为集合的名字。
- sadd【key】【value】 (重复值添加无效)
- srem 【key】【value】 删除 集合中的value值
- spop[key] 随机删除一个值,并返回
- smembers [key] 显示集合的值
- sdiff 【key1】【key2】 差集 key1+key2-key2
- sdiffstore [saveKey][key1][key2][key3] 与key1的差集,保存为saveKey
- sinter 【key1】【key2】交集
- sinterstore [saveKey][key1][key2][key3] 交集并保存为saveKey
- sunion [key1][key2]并集
- sunionstore [saveKey][key1][key2] 并集并保存为saveKey
- smove [key1] [key2][value] 把value从key1移动到key2
- scard 【key】 set.size()
- sismember [key] [value] value是不是属于该集合
- srandmember [key] 随机返回一个元素,但是不删除该元素
sorted sets 有序集合(zset)
set的加强版本,增加了顺序属性。zset是一个String类型的元素集合,但是包含了一个score的值,用于排序。
- zadd 【key】【score】【value】 添加,多次添加同一个value,将以最后一次为准
1.zrem [key] [value] 删除value - 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的值 - zrange [key] [startIndex][endIndex] withscores 从小到大返回startIndex到endIndex的值
- zrangebyscore [key][minScore][maxScore] withscores 返回集合中score在范围内的元素
- zcount [key][minScore][maxScore] key中score在指定范围中的值。
- zcard [key] 返回集合中的元素
- zscore 【key】[value] 该value的score
- zremrangebyrank [key] [rankStart][randEnd] 删除集合中,在指定区间的元素。
- zremrangebyscore 删除集合中score在给定区间的值
Redis常用命令
键值相关
- keys 【pattern】 满足pattern的所有可以
- exists [key]是否存在key
- del 删除一个key
- expire key [time(秒)] 给一个key设置过期时间
- move key 【db no】 将key移动到别的数据库(0-15)
- persist [key] 移除该key 的过期时间
- ttl 【key】 该key的剩余时间 -1 为没有过期时间
- randomkey 随机返回一个key
- rename [key][newKey] 设置新的age
- type [key] 该key的类型
服务器相关命令
- ping redis连接是否存在
- echo '1111' 打印1111
- select [0-15] 选择数据库
- quit 退出连接
- dbsize 当前数据库中的数量
- info redis服务器信息
- monitor 实时转存收到的请求
- config get [key] 获取配置信息
- flushdb 删除当前选择的数据库里面的所有key
- flushall 删除所有数据库的值
网友评论