什么是Redis?
Redis:REmote DIctionary Server(远程字典服务器)是完全开源免费的,用C语言编写的,遵守BSD协议,是一个高性能(key/value)分布式内存数据库,基于内存运行并支持持久化的NoSQL数据库,是当前最热门的NoSql数据库之一,也被人们称为数据结构服务器。
Redis 与其他 key - value 缓存产品有以下三个特点:
Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用;
Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储;
Redis支持数据的备份,即master-slave模式的数据备份。
Redis 能干嘛?:
内存存储和持久化:redis支持异步将内存中的数据写到硬盘上,同时不影响继续服务;
取最新N个数据的操作,如:可以将最新的10条评论的ID放在Redis的List集合里面;
模拟类似于HttpSession这种需要设定过期时间的功能;
发布、订阅消息系统;
定时器、计数器;
Redis启动后杂项基础知识讲解:
单进程:
单进程模型来处理客户端的请求。对读写等事件的响应是通过对epoll函数的包装来做到的。Redis的实际处理速度完全依靠主进程的执行效率
epoll是Linux内核为处理大批量文件描述符而作了改进的epoll,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率。
默认16个数据库,类似数组下表从零开始,初始默认使用零号库
select命令切换数据库
dbsize查看当前数据库的key的数量
flushdb:清空当前库
Flushall:通杀全部库
统一密码管理:16个库都是同样密码,要么都OK要么一个也连接不上
Redis索引都是从零开始
为什么默认端口是6379
Redis的五大数据类型:
String(字符串)
string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。
string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。
string类型是Redis最基本的数据类型,一个redis中字符串value最多可以是512M
Hash(哈希)
Redis hash 是一个键值对集合。
Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。类似Java里面的Map<String,Object>
List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)。
它的底层实际是个链表 。
Set(集合)
Redis的Set是string类型的无序集合。它是通过HashTable实现实现的。
zset(sorted set:有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。
redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但分数(score)却可以重复。
Redis常用命令:
常用Redis 键(key)命令:
keys *
exists key的名字:判断某个key是否存在
move key db :当前库就没有了,被移除了
expire key 秒钟:为给定的key设置过期时间
ttl key 查看还有多少秒过期,-1表示永不过期,-2表示已过期
type key 查看你的key是什么类型
常用Redis字符串(String)命令: 单值单value
1. set/get/del/append/strlen
2.Incr/decr/incrby/decrby,一定要是数字才能进行加减
3.getrange/setrange:
getrange:获取指定区间范围内的值,类似between......and的关系,从0到-1表示全部
setrange设置指定区间范围内的值,格式是setrange key值 具体值
4. setex(set with expire)键秒值/setnx(set if not exist):
setex:设置带过期时间的key,动态设置。
setex 键 秒值 真实值
setnx:只有在 key 不存在时设置 key 的值。
5. mset/mget/msetnx:
mset:同时设置一个或多个 key-value 对。
mget:获取所有(一个或多个)给定 key 的值。
msetnx:同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。
6. getset(先get再set):
getset:将给定 key 的值设为 value ,并返回 key 的旧值(old value)。简单一句话,先get然后立即set
Redis列表(List)常用命令:单值多value
1. lpush/rpush/lrange
2. lpop/rpop
3. lindex,按照索引下标获得元素(从上到下):通过索引获取列表中的元素 lindex key index
4. llen:
5. lrem key 删N个value:
从left往right删除2个值等于v1的元素,返回的值为实际删除的数量
LREM list 0 值,表示删除全部给定的值。零个就是全部值
6. ltrim key 开始index 结束index,截取指定范围的值后再赋值给key:
ltrim:截取指定索引区间的元素,格式是ltrim list的key 起始索引 结束索引
7. rpoplpush 源列表 目的列表: 移除列表的最后一个元素,并将该元素添加到另一个列表并返回
8. lset key index value
9. linsert key before/after 值1 值2: 在list某个已有值的前后再添加具体值
性能总结:
它是一个字符串链表,left、right都可以插入添加;
如果键不存在,创建新的链表;
如果键已存在,新增内容;
如果值全移除,对应的键也就消失了。
链表的操作无论是头和尾效率都极高,但假如是对中间元素进行操作,效率就很惨淡了。
Redis集合(Set)常用命令:单值多value
1. sadd/smembers/sismember
2. scard,获取集合里面的元素个数
3. srem key value 删除集合中元素
4. srandmember key 某个整数(随机出几个数):
* 从set集合里面随机取出2个
* 如果超过最大数量就全部取出,
* 如果写的值是负数,比如-3 ,表示需要取出3个,但是可能会有重复值。
5. spop key 随机出栈
6. smove key1 key2 在key1里某个值 作用是将key1里的某个值赋给key2
7. 数学集合类
差集:sdiff ,在第一个set里面而不在后面任何一个set里面的项
交集:sinter
并集:sunion
Redis哈希(Hash)常用命令(重要):KV模式不变,但V是一个键值对
1. hset/hget/hmset/hmget/hgetall/hdel
2. hlen
3. hexists key 在key里面的某个值的key
4. hkeys/hvals
5. hincrby/hincrbyfloat
6. hsetnx:不存在赋值,存在了无效。
Redis有序集合Zset(sorted set)常用命令:
多说一句
在set基础上,加一个score值。之前s et是k1 v1 v2 v3, 现在zset是k1 score1 v1 score2 v2
1. zadd/zrange
withscores
2. zrangebyscore key 开始score 结束score
withscores ( 不包含
limit 作用是返回限制
limit 开始下标步 多少步
3.zrem key 某score下对应的value值,作用是删除元素:
删除元素,格式是zrem zset的key 项的值,项的值可以是多个
zrem key score某个对应值,可以是多个值
4.zcard/zcount key score区间/zrank key values值,作用是获得下标值/zscore key 对应值,获得分数:
zcard :获取集合中元素个数
zcount :获取分数区间内元素个数,zcount key 开始分数区间 结束分数区间
zrank: 获取value在zset中的下标位置
zscore:按照值获得对应的分数
5. zrevrank key values值,作用是逆序获得下标值: 正序、逆序获得下标索引值
6. zrevrange
7. zrevrangebyscore key 结束score 开始score: zrevrangebyscore zset1 90 60 withscores 分数是反着来的