go手写Redis(1)之协议说明

手写Redis

参考大佬的go实现redis,自己实现一个简单版本的用于学习go以及网络编程相关

https://github.com/HDT3213/godis
https://coding.imooc.com/class/576.html #慕课网课程

源码地址:

https://gitee.com/haijun1998/go_redis

RESP协议

Redis Serialization Protocol redis序列化协议,包括五种消息类型

  • 正常回复
  • 错误回复
  • 整数
  • 多行字符串
  • 数组
正常回复
  • 以 " + " 开头,以 “\r\n” 结尾的字符串形式
+OK\r\n  #指令正常
错误回复
  • 以 " - " 开头,以 “\r\n” 结尾的字符串形式
-Error message \r\n  #指令执行错误
整数

客户端跟Redis进行通信的格式

  • 以 " : " 开头,以 “\r\n” 结尾的字符串形式
:123456\r\n
多行字符串
  • 以 " $ " 开头,后面跟实际发送字节数,以 “\r\n” 结尾的字符串形式
如果发送:hello world
$11\r\nhello world\r\n  #$开头实际的字节长度,后面以\r\n结尾
发送空字符串
$0\r\n\r\n    #\r\n发送空字节
数组
  • 以 " * " 开头,后面跟成员的个数
SET key value  3个字符串就是3个成员
转换后:
*3\r\n$3\r\nSET\r\n$3\r\nkey\r\n$5\r\nvalue\r\n

上面就是 RESP 协议的说明,下面说明一下源码的模块

模块说明

  • aof:redis aof实现
  • common:定义常量的模块
  • config:用于解析 redis.conf 的配置
  • database:数据库核心,包括数据库、命令的执行
  • datastruct:数据结构模块
  • interface:顶级接口定义的模块
  • lib:一些工具文件的定义
  • logs:自定义的日志打印
  • resp:连接器、处理器、响应体的定义和实现
  • tcp:tcp协议监听处理
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值