go实现Redis读写分离示例详解
本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《go实现Redis读写分离示例详解》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~
我们为什么需要了解RESP协议?
本篇文章目的为探究RESP协议,而非编写读写中间件,这点要清楚。
关于这个问题,我想通过一个实例来解释,我们编写Redis中间件,为什么需要了解RESP协议。

以上代码是编写了一个非常简单的TCP服务器,我们监听8888端口,尝试使用redis-cli -p 8888连接服务器后,而后查看打印出来的应用层报文。
我们尝试执行下该代码,并且输入redis-cli -p 8888进行连接。

我们编写的服务器获取redis客户端的报文为:
*1
$7
COMMAND
上面这个就是RESP协议的内容了,所以说,我们要编写一个Redis的中间件,我们需要先了解一下RESP协议才行。
什么是RESP协议
官网有相关的解释: https://redis.io/docs/reference/protocol-spec/
RESP协议创建之初是专门为了Redis服务器和客户端的通信而设计的,该协议在Redis 1.2中引入,并且在Redis 2.0中,成为Redis通信的标准协议。该协议有如下优点:
- 实现简单
- 快速解析
- 直接可阅读
RESP根据其协议前缀,可以序列化不同的数据类型,例如: 整数、字符串、数组 等,还能标注 正常输出 和 错误输出等。除了流水线和发布订阅以外,RESP协议应该是最简单的请求-响应协议了。关于更多介绍,大佬们可以看看上面注释的官方文档。
RESP协议规范
RESP协议不同的部分使用\r\n(换行符)来进行分割,其支持5种数据类型,分别为: 简单字符串、错误、整数、复杂字符串 和 数组组成,我们列个表格来讲下。
| 类型 | 前缀 | 备注 |
|---|---|---|
| 简单字符串 | + | 简单字符串以+开头 |
| 错误数据 | - | 错误数据以-开头 |
| 整数 | : | 整数以:开头 |
| 复杂字符串 | $ | 复杂字符串以$开头 |
| 数组 | * | 数组以*开头 |
我当初看到这个的时候,也是迷迷糊糊的,到底什么意思呢? 哎,我们举个例子你就明白了。
若我们想执行
set juejinName pdudo
若使用RESP 协议应当如何编写呢?应当编写如下:
*3 $3 set $10 juejinName $5 pdudo
那我们来解释一下*3代表有3个数组,而$3代表复杂字符串有长度为3,值为set, $10代表复杂字符串长度为10,值为juejinName, $5代表复杂字符串长度为5,值为pdudo。
我们结合上述信息,可以画一张图。

这就是协议的内容了。
而协议前缀+、-、:则要简单的多,直接跟数据即可,
例如:
+
+OK
-
-ERR syntax error
:
:3
如何使用该协议请求Redis
我们已经学习了相关的RESP协议,那么我们如何学习呢? 我们可以使用telnet命令来操作即可。
在此,我们准备几条命令,我们会将其转换为RESP格式,且将其发送到redis服务器。
命令
set name pdudo get name lpush pn 1 llen pn
转换为RESP格式
*3 $3 set $4 name $5 pdudo *2 $3 get $4 name *3 $5 lpush $2 pn $1 1 *2 $4 llen $2 pn
我们将其放置到telnet中执行一下呢

现在回头看看官网文档所提及的,该协议实现简单,直接可阅读,是不是理解的更加深刻了呢?
使用go编写Redis中间件实现读写分离
本篇暂不解释代码,而后单独开一篇谈论中间件代码。
实现该功能,其实本质上是区分命令是查询还是写入,若是查询,则直接转发到从库,而写入,则转发到主库即可,其架构图可以理解为如下:

我们已经有了目前的架构。
| 主机 | 端口 | 密码 | 角色 |
|---|---|---|---|
| 127.0.0.1 | 6379 | 无 | 主库 |
| 127.0.0.1 | 7380 | 无 | 从库 |
相关代码已经放到了 gitee.com/pdudo/golea…
我们来看看实际效果呢:

总结
其实本篇文章核心的点是探究RESP协议,而我们使用go编写了一个软件,用于解析RESP协议,从而获取执行的命令,再根据命令属性,从而转发从库或者主库,以此来达到读写分离的效果。再次提及一下核心点是拆解RESP协议。
怎么样,好玩吧,动动你的小手指,快来试试吧。
以上就是《go实现Redis读写分离示例详解》的详细内容,更多关于golang的资料请关注golang学习网公众号!
Golang 手写一个简单的并发任务 manager
- 上一篇
- Golang 手写一个简单的并发任务 manager
- 下一篇
- Golang Mutex 原理详细解析
-
- 腼腆的芹菜
- 这篇技术贴出现的刚刚好,太细致了,赞 ??,收藏了,关注楼主了!希望楼主能多写Golang相关的文章。
- 2023-05-09 01:35:37
-
- 正直的帆布鞋
- 很棒,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢楼主分享博文!
- 2023-04-04 19:29:56
-
- 阳光的玫瑰
- 这篇技术文章太及时了,太详细了,很棒,mark,关注师傅了!希望师傅能多写Golang相关的文章。
- 2023-03-14 15:16:12
-
- 贤惠的蜻蜓
- 太详细了,码住,感谢楼主的这篇技术文章,我会继续支持!
- 2023-02-25 20:22:44
-
- 专注的外套
- 这篇技术贴真是及时雨啊,大佬加油!
- 2023-02-20 04:48:53
-
- 心灵美的白云
- 这篇文章内容真及时,太详细了,赞 ??,mark,关注作者大大了!希望作者大大能多写Golang相关的文章。
- 2023-02-10 18:27:02
-
- 漂亮的彩虹
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢up主分享技术文章!
- 2023-02-06 17:12:06
-
- 如意的黑夜
- 真优秀,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享文章!
- 2023-02-05 01:50:41
-
- 魁梧的帆布鞋
- 很好,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢博主分享博文!
- 2023-01-29 12:12:40
-
- 干净的香氛
- 这篇技术文章出现的刚刚好,太细致了,真优秀,已加入收藏夹了,关注师傅了!希望师傅能多写Golang相关的文章。
- 2023-01-25 17:47:05
-
- 悦耳的蜡烛
- 这篇技术贴真及时,细节满满,感谢大佬分享,mark,关注up主了!希望up主能多写Golang相关的文章。
- 2023-01-11 01:17:26
-
- 不安的面包
- 太全面了,码住,感谢楼主的这篇文章,我会继续支持!
- 2023-01-03 00:24:04
-
- Golang · Go教程 | 1天前 | map · 并发安全 · RWMutex · sync.Map · Go教程 · 并发安全 RWMutex sync.Map Go map并发读写 go test race
- Go map 并发读写崩溃怎么办:从复现报错到 RWMutex 修复的完整流程
- 272浏览 收藏
-
- Golang · Go教程 | 3天前 | singleflight · 并发控制 · Go教程 · 缓存治理 · 接口优化 · Go 并发请求 缓存击穿 singleflight 缓存回填
- Go singleflight 防缓存击穿实战:相同请求只查一次数据库
- 114浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ljg-skills
- ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
- 161次使用
-
- MELO音乐
- MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
- 177次使用
-
- UniScribe
- UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
- 159次使用
-
- 剧云
- 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
- 315次使用
-
- 万象有声
- 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
- 318次使用
-
- Golang 实现Redis 协议解析器的解决方案
- 2022-12-23 109浏览
-
- go+redis实现消息队列发布与订阅的详细过程
- 2023-01-07 161浏览
-
- Go语言操作redis数据库的方法
- 2023-01-07 214浏览
-
- 详解如何利用amoeba(变形虫)实现mysql数据库读写分离
- 2022-12-28 279浏览
-
- goredis之redigo的使用
- 2023-01-07 131浏览

