认识redis | 青训营笔记

105 阅读2分钟

这是我参与「第五届青训营 」伴学笔记创作活动的第 1 天

Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库。

1. Redis Serialization Protocol (RESP)

redis序列化协议

  • 正常回复
  • 错误回复
  • 整数
  • 多行字符串
  • 数组

正常回复

以“+”开头,以“\r\n”结尾的字符串形式

+OK\r\n

错误回复

以“-”开头,以“\r\n”结尾的字符串形式

-EOORO MESSAGE\r\n

整数

以“:”开头,以“\r\n”结尾的字符串形式

:123456\r\n

多行字符串

以“$”开头,后跟实际发送字节数,以“\r\n”结尾

一般字符串

"imooc.com"

$\9\r\nimooc.com\r\n

空串

""

$0\r\n\r\n

nil串

$-1\r\n

含换行符等特殊字符串

"imooc\r\nmoody"

$14\r\nimooc\r\nmoody\r\n

数组

以"*"开头,后跟成员个数

SET key value

*3\r\n$3\r\nSET\r\n$3\r\nkey\r\n$5\r\nvalue\r\n

2 Redis数据类型

Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

String

string 是 redis 最基本的类型,一个 key 对应一个 value。

string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。

Hash

Redis hash 是一个键值(key=>value)对集合。

Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。

List

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。

Set

Redis 的 Set 是 string 类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

Zset

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复。

3 Redis应用案例

  • 掘金连续签到,需要了解GET/SET,Key过期
  • 掘金用户计数,使用到HASH
  • 排行榜ZSET
  • 使用SETNX实现分布式锁

4 Redis注意事项

  • 大Key:Value大于10KB就是大Key,使用大Key将导致Redis系统不稳定
  • 热Key:一个Key的QPS特别高,将导致Redis实例出现负载突增,负责均衡流量不均的情况。导 致单实例故障
  • 慢查询:大Key、热Kye的读写;一次操作过多的Key(mset/hmset/sadd/zadd)
  • 导致缓存穿透、缓存雪崩的场景及避免方案