当前位置: 首页 > ai >正文

Redis——通信协议

目录

1.RESP协议

2.RESP协议——数据类型

3.总结


1.RESP协议

Redis是一个CS架构的软件,通信一般分两步(不包括pipeline和pubsub):


1.客户端(client)向服务端(server)发送一条命令
2.服务端解析并执行命令,返回响应结果给客户端
因此客户端发送命令的格式,服务端响应结果的格式必须有一个规范,这个规范就是通信协议。


而在redis中采用的是RESP(redis serialization prot)协议:

  • Redis1.2版本引入了resp协议
  • Redis2.0版本中成为与redis服务端通信的标准,称为RESP2
  • Redis6.0版本中,从RESP2开级到了RESP3协议,增加了更多数据类型并且支持6.0的新特性一客户端缓存

但目前,为了兼容性问题,默认使用的依然时RESP2协议,也是我们要学习的协议版本(以下进程RESP)

2.RESP协议——数据类型

在RESP中,通过首字节的字符来区分不同数据类型,常用的数据类型包括5种:

单行字符串:首字节是'+',后面跟上单行字符串,以CRLF("\r\n")结尾。例如返回"ok": "+ok\r\n"(二进制不安全)
错误(Errors):首字节是'-',与单行字符串格式一样,只是字符审是异常信息,例如:"-Errormessage\r\n"
数值:首字节是':',后面跟上数字格式的字符串,以CRLF结尾。例如:":10\r\n"
多行字符串:首字节是'$',表示二进制安全的字符串,最大支持512MB(二进制安全)

  • 如果大小为0,则代表空字符串:"$0/r\n\r\n"
  • 如果大小为-1,则代表不存在:"$-1/r\n" 字符串占用

数组:首字节是‘*’,后面跟上数组元素个数,再跟上元素,元素数据类型不限。

 

3.总结

RESP 通信协议以其简洁、高效和易读的特点,成为了分布式系统和数据库领域的重要通信协议。无论是 Redis 开发者,还是从事分布式系统设计的工程师,掌握 RESP 协议的原理和应用都具有重要意义。

http://www.xdnf.cn/news/723.html

相关文章:

  • 第35讲:构建属于自己的遥感大模型平台,并接入地理数据工作流
  • Ubuntu修改Swap交换空间大小
  • 深入浅出 C++ 核心基础:从语法特性到入门体系构建
  • C语言if
  • 大模型之路(day 1)
  • 嵌入式学习——远程终端登录和桌面访问
  • Java Web项目(一)
  • Mysql相关知识2:Mysql隔离级别、MVCC、锁
  • 深度可分离卷积与普通卷积的区别及原理
  • 【C++】继承----上篇
  • mysql
  • QSS【QT】
  • 常见超低噪声 LDO,ADM7150、LP5907、SGN2036、TPL910
  • 力扣刷题 - 203.移除链表元素
  • 4.20刷题记录(单调栈)
  • 基于springboot的商城
  • 积木报表查询出现jdbc.SQLServerException: 对象名 ‘user_tab_comment 的解决方法
  • 力扣算法ing(61 / 100)
  • 5.1 掌握函数定义与参数传递的奥秘
  • 【Qt】信号和槽
  • [安全实战]逆向工程核心名词详解
  • DAY6:从执行计划到索引优化的完整指南
  • React基础知识(补充中)
  • PyTorch基础学习系列一
  • 安卓手机怎样配置数据加速
  • Java File 类详解
  • 从事计算机视觉需要掌握哪些知识
  • 微信小程序通过mqtt控制esp32
  • Map遍历
  • Linux 进程概念补充 (自用)