Redis协议详解

Redis协议详解

由于前段时间在使用ServiceStack.Redis感觉不怎么方便和其代码实现也不理想所以就产生编写一个Redis .Net Client的想法(毕竟自己动手丰衣足食啊).实现的目的就是可以更简单了操作Redis并提供更多的数据处理方式如:String,json和Protobuf等。在操作Redis其实是通过TCP等方式来处理,所以它和其他网络服务一样有一个交互协议;Redis的交互协议比较怪异,第一次看感觉制定这协议很不合理……不过理解下来协议总体来说还是比较简单。

Redis的通讯协议可以说大集汇了……消息头标识,消息行还有就行里可能还有个数据块大小描述.首先Redis是以行来划分,每行以\r\n行结束。每一行都有一个消息头,消息头共分为5种分别如下:

(+) 表示一个正确的状态信息,具体信息是当前行+后面的字符。

(-)  表示一个错误信息,具体信息是当前行-后面的字符。

(*) 表示消息体总共有多少行,不包括当前行,*后面是具体的行数。

($) 表示下一行数据长度,不包括换行符长度\r\n,$后面则是对应的长度的数据。

(:) 表示返回一个数值,:后面是相应的数字节符。

以上就是Redis协议的基础组成部分,下面来分析几个指令了解一下具体相关指令和返回情况.

SET

C:

?
1
SET HENRY  HENRYFAN

以上命令是设置HENRY 的值为HENRYFAN.在Redis的通讯协议上会以空格把命令拆分成三行;得到最终的命令如下:

?
1
2
3
4
5
6
7
*3\r\n
$3\r\n
SET\r\n
$5\r\n
HENRY\r\n
$8\r\n
HENRYFAN\r\n

S:

服务端操作成功

?
1
+OK\r\n

如果出现错误服务端会返回

?
1
-错误信息\r\n

GET

C:

?
1
GET HENRY

产生的通讯指令是:

?
1
2
3
4
5
*2\r\n
$3\r\n
GET\r\n
$5\r\n
HENRY\r\n

S:

 如果存在这个Key则返回

?
1
2
$8\r\n
HENRYFAN\r\n

不存在返回

?
1
$-1\r\n

HKEYS

C:

?
1
HKEYS HENRY

以上命令是获取对应HENRY有多少个field成员

?
1
2
3
4
5
*2\r\n
$5\r\n
HKEYS\r\n
$5\r\n
HENRY\r\n

S:

如果不存在任何字段信息

?
1
*0\r\n

如果存在QQ字段信息

?
1
2
3
*1\r\n
$2\r\n
QQ\r\n

HMGET

C:

?
1
HMGET HENRY QQ

以上命令是获取HENRY的QQ信息。

?
1
2
3
4
5
6
7
*3\r\n
$5\r\n
HMGET\r\n
$5\r\n
HENRY\r\n
$2\r\n
QQ\r\n

S:

如果不存在字段值

?
1
2
*1\r\n
$-1\r\n

存在字段值

?
1
2
3
*1\r\n
$8\r\n
28304340\r\n

以上主要列举Redis普遍处理的一些情况,由于指令太多就不一一列举了,如果有需要自己实现Client的朋友可以到Redis官方看相关命令文档。

分享一下新完成的功能

设置用户的UserBase和Contact字段信息

?
1
2
3
4
5
6
7
8
9
10
11
12
UserBase user = new  UserBase();
             user.Name = "henryfan" ;
             user.City = "guangzhou" ;
             user.Counrty = "cn" ;
             user.Age = 18;
             Contact contact = new  Contact();
             contact.EMail = "[email protected]" ;
             contact.Phone = "111111" ;
             contact.QQ = "28304340" ;
             ProtobufRecord pr = new  ProtobufRecord( "henryfan_pb" );
             pr.Set<UserBase>(user).Set<Contact>(contact);
             pr.Save(db);

获取指定用户的UserBase和Contact字段信息

?
1
2
3
4
5
6
ProtobufRecord pr = new  ProtobufRecord( "henryfan_pb" );
             pr.Load<UserBase, Contact>(db);
             foreach  (Field item in  pr.Fields)
             {
                 Console.WriteLine( "{0}:{1}" , item.Name, item.Value);
             }

你可能感兴趣的:(redis)