一、什么是RESP
Redis是Redis序列化协议,Redis客户端RESP协议与Redis服务器通信。Redis协议在以下几点之间做出了折衷:
- 简单的实现
- 快速地被计算机解析
- 简单得可以能被人工解析
二、RESP协议描述
RESP协议在Redis 1.2中引入,但在Redis 2.0中成为与Redis服务器通信的标准方式。这个通信方式就是Redis客户端实现的协议。RESP实际上是一个序列化协议,它支持以下数据类型:简单字符串、错误、整数、大容量字符串和数组。
1、RESP在Redis中用作请求-响应协议的方式如下:
- 客户端将命令以批量字符串的RESP数组的形式发送到Redis服务器,如下:
SET mykey myvalue
*3
$3
SET
$5
mykey
$7
myvalue
*3:SET mykey myvalue 这数组的长度
$3:表示下面的字符长度是3,这里是SET长度是
$5:表示下面的字符的长度是5,这里是mykey的长度
$7:表示下面的字符的长度是7,这里是myvalue的长度
- 服务器根据命令实现使用其中一种RESP类型进行响应
2、在RESP中,某些数据的类型取决于第一个字节:
- For Simple Strings the first byte of the reply is "+" 简单字符串回复的第一个字节将是“+”
比如:向服务器发送"set toby xu"命令,实际上服务器的返回是:"+OK\r\n"
- For Errors the first byte of the reply is "-" 错误消息,回复的第一个字节将是“-”
比如:向服务器发送"add toby xu"命令,实际上服务器的返回是:"-ERR unknown command `add`, with args beginning with: `toby`, `xu`,\r\n"
- For Integers the first byte of the reply is ":" 整型数字,回复的第一个字节将是“:”
比如:向服务器发送"incr count"命令,实际上服务器的返回是:":6\r\n"
- For Bulk Strings the first byte of the reply is "$" 批量回复,回复的第一个字节将是“$”
比如:向服务器发送"get toby"命令,实际上服务器的返回是:"$2\r\nxu\r\n"
- For Arrays the first byte of the reply is "*" 数组回复的第一个字节将是“*”
比如:向服务器发送"hgetall toby_h"命令,实际上服务器的返回是:"*4\r\n$4\r\njava\r\n$3\r\