您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

go如何实现Redis读写分离

2024/4/15 2:41:26发布20次查看
我们为什么需要了解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$3set$10juejinname$5pdudo
那我们来解释一下*3代表有3个数组,而$3代表复杂字符串有长度为3,值为set, $10代表复杂字符串长度为10,值为juejinname, $5代表复杂字符串长度为5,值为pdudo。
我们结合上述信息,可以画一张图。
这就是协议的内容了。
而协议前缀+、-、:则要简单的多,直接跟数据即可,
例如:
+
+ok
-
-err syntax error
:
:3
如何使用该协议请求redis我们已经学习了相关的resp协议,那么我们如何学习呢? 我们可以使用telnet命令来操作即可。
在此,我们准备几条命令,我们会将其转换为resp格式,且将其发送到redis服务器。
命令
set name pdudoget namelpush pn 1llen pn
转换为resp格式
*3$3set$4name$5pdudo*2$3get$4name*3$5lpush$2pn$11*2$4llen$2pn
我们将其放置到telnet中执行一下呢
现在回头看看官网文档所提及的,该协议实现简单,直接可阅读,是不是理解的更加深刻了呢?
使用go编写redis中间件实现读写分离本篇暂不解释代码,而后单独开一篇谈论中间件代码。
实现该功能,其实本质上是区分命令是查询还是写入,若是查询,则直接转发到从库,而写入,则转发到主库即可,其架构图可以理解为如下:
我们已经有了目前的架构。
主机端口密码角色
127.0.0.1 6379 无 主库
127.0.0.1 7380 无 从库
以上就是go如何实现redis读写分离的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product