Redis
Redis
Redis(Remote Dictionary Server ),即远程字典服务,是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
1.1 定义
redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
1.2常用命令
全局操作key
KEYS * 查看KEY支持通配符
DEL 删除给定的一个或多个key
EXISTS 检查是否存在
RENAME 变更KEY名
SORT 键值排序,有非数字时报错
TYPE 返回键所存储值的类型
DUMP RESTORE 序例化与反序列化
EXPIRE\ PEXPIRE 以秒\毫秒设定生存时间
TTL\ PTTL 以秒\毫秒为单位返回生存时间
PERSIST 取消生存实现设置
RANDOMKEY 返回数据库中的任意键
- TYPE key — 用来获取某key的类型
- KEYS pattern — 匹配所有符合模式的key,比如KEYS * 就列出所有的key了,当然,复杂度O(n)
- RANDOMKEY - 返回随机的一个key
- RENAME oldkey newkey— key也可以改名
列表操作,精华
- RPUSH key string — 将某个值加入到一个key列表末尾
- LPUSH key string — 将某个值加入到一个key列表头部
- LLEN key — 列表长度
- LRANGE key start end — 返回列表中某个范围的值,相当于mysql里面的分页查询那样
- LTRIM key start end — 只保留列表中某个范围的值
- LINDEX key index — 获取列表中特定索引号的值,要注意是O(n)复杂度
- LSET key index value — 设置列表中某个位置的值
- LPOP key
- RPOP key — 和上面的LPOP一样,就是类似栈或队列的那种取头取尾指令,可以当成消息队列来使用了
集合操作
- SADD key member — 增加元素
- SREM key member — 删除元素
- SCARD key — 返回集合大小
- SISMEMBER key member — 判断某个值是否在集合中
- SINTER key1 key2 ... keyN — 获取多个集合的交集元素
- SMEMBERS key — 列出集合的所有元素
- 还有Multiple DB的命令,可以更换db,数据可以隔离开,默认是存放在DB 0。
1.3 存储
redis使用了两种文件格式:全量数据和增量请求。
全量数据格式是把内存中的数据写入磁盘,便于下次读取文件进行加载;
增量请求文件则是把内存中的数据序列化为操作请求,用于读取文件进行replay得到数据,序列化的操作包括SET、RPUSH、SADD、ZADD。
redis的存储分为内存存储、磁盘存储和log文件三部分,配置文件中有三个参数对其进行配置。
1.4 应用场景
redis的应用场景
• 缓存(数据查询、短连接、新闻内容、商品内容等等)
• 聊天室的在线好友列表
• 任务队列。(秒杀、抢购、12306等等)
• 应用排行榜
• 网站访问统计
• 数据过期处理(可以精确到毫秒
• 分布式集群架构中的session分离
1.5常用注解
- @Cacheable
属性如下图
用于查询和添加缓存,第一次查询的时候返回该方法返回值,并向 Redis 服务器保存数据。
以后调用该方法先从 Redis 中查是否有数据,如果有直接返回 Redis 缓存的数据,而不执行方法里的代码。如果没有则正常执行方法体中的代码。
value 或 cacheNames 属性做键,key 属性则可以看作为 value 的子键, 一个 value 可以有多个 key 组成不同值存在 Redis 服务器。
验证了下,value 和 cacheNames 的作用是一样的,都是标识主键。两个属性不能同时定义,只能定义一个,否则会报错。
- @CachePut
更新 Redis 中对应键的值。属性和 @Cacheable 相同
- @CacheEvict
删除 Redis 中对应键的值。