资讯专栏INFORMATION COLUMN

用 Go 来了解一下 Redis 通讯协议

cnsworder / 1536人阅读

摘要:用来了解一下通讯协议原文地址用来了解一下通讯协议都有那么多包来支撑你使用,那你是否有想过有了服务端,有了客户端,他们俩是怎样通讯,又是基于什么通讯协议做出交互的呢介绍基于我们的目的,本文主要讲解和实践的通讯协议的客户端和服务端是通过连接来进

用 Go 来了解一下 Redis 通讯协议
原文地址:用 Go 来了解一下 Redis 通讯协议

Go、PHP、Java... 都有那么多包来支撑你使用 Redis,那你是否有想过

有了服务端,有了客户端,他们俩是怎样通讯,又是基于什么通讯协议做出交互的呢?

介绍

基于我们的目的,本文主要讲解和实践 Redis 的通讯协议

Redis 的客户端和服务端是通过 TCP 连接来进行数据交互, 服务器默认的端口号为 6379

客户端和服务器发送的命令或数据一律以 (CRLF)结尾(这是一条约定)

协议

在 Redis 中分为请求回复,而请求协议又分为新版和旧版,新版统一请求协议在 Redis 1.2 版本中引入,最终在 Redis 2.0 版本成为 Redis 服务器通信的标准方式

本文是基于新版协议来实现功能,不建议使用旧版(1.2 挺老旧了)。如下是新协议的各种范例:

请求协议

1、 格式示例

*<参数数量> CR LF
$<参数 1 的字节数量> CR LF
<参数 1 的数据> CR LF
...
$<参数 N 的字节数量> CR LF
<参数 N 的数据> CR LF

在该协议下所有发送至 Redis 服务器的参数都是二进制安全(binary safe)的

2、打印示例

*3
$3
SET
$5
mykey
$7
myvalue

3、实际协议值

"*3
$3
SET
$5
mykey
$7
myvalue
"

这就是 Redis 的请求协议规范,按照范例1编写客户端逻辑,最终发送的是范例3,相信你已经有大致的概念了,Redis 的协议非常的简洁易懂,这也是好上手的原因之一,你可以想想协议这么定义的好处在哪?

回复

Redis 会根据你请求协议的不同(执行的命令结果也不同),返回多种不同类型的回复。在这个回复“协议”中,可以通过检查第一个字节,确定这个回复是什么类型,如下:

状态回复(status reply)的第一个字节是 "+"

错误回复(error reply)的第一个字节是 "-"

整数回复(integer reply)的第一个字节是 ":"

批量回复(bulk reply)的第一个字节是 "$"

多条批量回复(multi bulk reply)的第一个字节是 "*"

有了回复的头部标识,结尾的 CRLF,你可以大致猜想出回复“协议”是怎么样的,但是实践才能得出真理,斎知道怕是你很快就忘记了

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/28787.html

相关文章

  • 使 TiKV 构建分布式类 Redis 服务

    摘要:提供了集群支持,但也不能支持跨多个节点的分布式事务。是一个高性能,支持分布式事务的数据库。譬如,我们就构建了,一个基于的,兼容的分布式关系型数据库。它使用作为每行的分隔符并且用不同的前缀来代表不同的类型。 什么是 Redis Redis 是一个开源的,高性能的,支持多种数据结构的内存数据库,已经被广泛用于数据库,缓存,消息队列等领域。它有着丰富的数据结构支持,譬如 String,Has...

    UnixAgain 评论0 收藏0

发表评论

0条评论

cnsworder

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<