Redis 的客户端和服务端之间采取了一种名为 RESP(REdis Serialization Protocol) 的协议,进行通信
在 RESP 中, 一些数据的类型通过它的第一个字节进行判断:
单行回复:回复的第一个字节是 "+"
错误信息:回复的第一个字节是 "-"
整形数字:回复的第一个字节是 ":"
多行字符串:回复的第一个字节是 "$"
数组:回复的第一个字节是 "*"
协议的每部分都是以 “\r\n” (CRLF) 结尾的。另外 RESP 是二进制安全的,不需要处理从一个进程到另一个进程的传输,因为它使用了前缀长度进行传输。
以 “+” 开头,以 “\r\n” 结尾的字符串形式。
+OK\r\n
“+” 替换成了 “-”。错误信息会被客户端视为异常,组成错误类型的是错误消息本身
127.0.0.1:6379> earaer
-ERR unknown command 'earaer'\r\n # 服务端实际返回, 下同
---
(error) ERR unknown command 'earaer'
127.0.0.1:6379> set name asdasd zsdzsd
-ERR syntax error\r\n
---
(error) ERR syntax error
以 “:” 作为前缀,以CRLF作为结尾的字符串来表示整数。
用于表示二进制安全的字符串,最大为 512M,Bluk Strings的编码格式,第一个字节为$
$3\r\nfoobar\r\n
$0\r\n\r\n -> ""
$-1\r\n -> nil
当服务端需要返回多个数据给客户端的时候,就是使用Arrays进行返回的,如LRANGE命令返回的就是一个数组。此外,客户端发送给服务端的命令,也都是使用Arrays进行发送的。第一个字符为*
空数组
*0\r\n
包含两个Bluk Strings元素,元素内容分别为foo跟bar的Arrays表示为
*2\r\n$3\r\nfoo\r\n$3\r\nbar\r\n
Arrays中各个元素的数据类型可以不同,比如包含一个Integer类型跟一个Simple Strings类型的Arrays,表示为
*2\r\n:1\r\n+hello\r\n