REmote DIctionary Server(远程字典服务器)
是完全开源免费的,用C语言编写的,遵守BSD协议,是一个高性能的(Key-Value)分布式内存数据库。
基于内存运行并支持持久化的NoSQL数据库,是当前最热门的NoSQL数据库之一,也被人称为数据结构服务器。
1)Redis支持数据持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用
2)Redis不仅仅支持简单的key-value类型的数据,同时还提供list、set、zset、hash等数据结构的存储
3)Redis支持数据的备份,即master-slave模式的数据备份
1)内存存储和持久化:redis支持异步将内存中的数据写到硬盘上,同时不影响继续服务。
2)取最新记录。如:将最新的10条评论的ID放在Redis的List集合里面。
3)模拟类似于HttpSession这种需要设定过期时间的功能
4)发布、订阅消息系统
5)定时器、计数器
启动服务端: redis-server
连接客户端: redis-cli -p 6379(端口)
存: set 键 值
取: get 键
查看: keys 匹配
清空当前库: FLUSHDB
清空所有库: FLUSHALL
选择库: select 坐标
1)判断是否存在
EXISTS 键
2)查询当前库的key
keys (匹配)
3)移动key
move 键 库号
4)为给定的key设置过期时间
expire 键 秒钟
5)查看还有多少秒过期,-1表示永不过期,-2表示已过期
ttl 键
6)查看你的key是什么类型
type 键
7)删除键
del 键
string是redis最基本的类型,string类型是二进制安全的。可以包含任何数据。比如jpg图片或者序列化对象。一个redis字符串value最多可以是512M。
1)追加
append 键 内容
2)获得字符串长度
strlen 键
3)针对数字的操作(一定要是数字)
增加1: incr 键
减少1: decr 键
增加某值: incrby 键 值
减少某值: decrby 键值 值
4)截取操作
getrange 键 起始坐标 结束坐标(-1表示全部)
5)范围替换
setrange 建 起始坐标 替换内容
6)创建的时候设置过期时间(set with expire)
创建并设置:setex 键 秒速 值
7)不存在才能创建(存在则不会创建)(set if not exist)
setnx 键 值
8)创建多个和获取多个 mset/mget
msetnx(不存在才创建成功)
9)先获取再改值 getset
底层是个链表
1)lpush/rpush/lrange
2)左出右出 lpop/rpop
3)按坐标获取元素 lindex 键 下标序号
4)获取集合长度 llen 键
5)删除N个值 lrem 键 个数 值
6)截取指定范围的值后再赋值给key ltrim key 开始位置 结束位置
7)转移1个元素 rpoplpush 原列表 目的列表
8)替换某个位置的值 lset key index value
8)在某个值旁边插入某个值 linsert key before/after 值1 值2
总结:
一、键不存在,创建新的链表,键已存在,新增内容。
二、没有值则对应键也消失
三、对头位置处理快,中间位置很尴尬~
Redis的Set是string类型的无序集合,它是通过HashTable实现的
1)插入 set key value1/value2/value3(value重复有且只添加一个)
2)查看 smembers key
3)存在多少个某值 sismember key value
4)获取集合里面的元素个数 scard key
5)删除集合中元素 srem key value
6)某个整数(随机出几个数) srandmember key 个数
7)随机出栈 spop key
8)将key1的某个值赋给key2 smove key1 key2 value
9)数字集合类的处理
差集:sdiff 源key 目标key
交集:sinter 源key 目标key
并集:sunion 源key 目标key
类似于java的Map
Redis hash 是一个键值对集合。是一个string类型的field和value的映射表,hash特别适合用于存储对象
1)hset/mget/hmset/hmget/hgetall/hdel
2)查询长度 hlen
3)某key是否存在某key hexists key1 key2
4)获取所有key hkeys key
5)获取所有value hvals key
6)加法 hincrby/hincrbyfloat
7)存在则赋值 hsetnx key主 key子 value
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员
不同的是每个元素都会关联一个double类型的分数
redis正式通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但分数(score)却可以重复。
1)zadd key 分数1 value1 分数2 value2
2)获取值 zrange key 起始位置 结束位置
3)连值带分数的获取 zrange key 起始位置 结束位置 withscores
4)根据分数范围来获取 zrangebyscore key 开始分数 结束分数
注:给结束分数带 ( 表示不包含
+limit 起始偏移量 截取个数
5)某分数下对应的value值,删除元素 zrem key
6)获取个数 zcard
7)获取分数区间个数 zcount key 开始分数 结束分数
8)根据值获取下标 zrank key value
9)根据值获取分数 zscore key value
10)逆序获取下标 zrevrank key value
11)逆序输出值 zrevrange key 开始位置 结束位置
12)逆序分数获取值 zrevrangebyscore key 高分数 低分数
原文:https://www.cnblogs.com/it-taosir/p/9893216.html