本篇内容主要讲解“go如何实现Redis读写分离”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“go如何实现Redis读写分离”吧!关于这免费云主机域名个问题,我想通过一个实例来解释,我们编写Redis
中间件,为什么需要了解RESP
协议。以上代码是编写了一个非常简单的TCP
服务器,我们监听8888
端口,尝试使用redis-cli -p 8888
连接服务器后,而后查看打印出来的应用层报文。我们尝试执行下该代码,并且输入redis-cli -p 8888
进行连接。我们编写的服务器获取redis
客户端的报文为:*1
$7
COMMAND上面这个就是RESP
协议的内容了,所以说,我们要编写一个Redis
的中间件,我们需要先了解一下RESP
协议才行。官网有相关的解释: https://redis.io/docs/reference/protocol-spec/RESP
协议创建之初是专门为了Redis
服务器和客户端的通信而设计的,该协议在Redis 1.2
中引入,并且在Redis 2.0
中,成为Redis
通信的标准协议。该协议有如下优点:实现简单快速解析直接可阅读RESP
根据其协议前缀,可以序列化不同的数据类型,例如: 整数、字符串、数组 等,还能标注 正常输出 和 错误输出等。除了流水线和发布订阅以外,RESP
协议应该是最简单的请求-响应协议了。关于更多介绍,大佬们可以看看上面注释的官方文档。RESP
协议不同的部分使用rn
(换行符)来进行分割,其支持5种数据类型,分别为: 简单字符串、错误、整数、复杂字符串 和 数组组成,我们列个表格来讲下。我当初看到这个的时候,也是迷迷糊糊的,到底什么意思呢? 哎,我们举个例子你就明白了。若我们想执行若使用RESP
协议应当如何编写呢?应当编写如下:那我们来解释一下*3
代表有3个数组,而$3
代表复杂字符串有长度为3,值为set
, $10
代表复杂字符串长度为10,值为juejinName
, $5
代表复杂字符串长度为5,值为pdudo
。我们结合上述信息,可以画一张图。这就是协议的内容了。而协议前缀+
、-
、:
则要简单的多,直接跟数据即可,例如:+
-
:
我们已经学习了相关的RESP
协议,那么我们如何学习呢? 我们可以使用telnet
命令来操作即可。在此,我们准备几条命令,我们会将其转换为RESP
格式,且将其发送到redis
服务器。命令转换为RESP
格式我们将其放置到telnet
中执行一下呢现在回头看看官网文档所提及的,该协议实现简单,直接可阅读,是不是理解的更加深刻了呢?本篇暂不解释代码,而后单独开一篇谈论中间件代码。实现该功能,其实本质上是区分命令是查询还是写入,若是查询,则直接转发到从库,而写入,则转发到主库即可,其架构图可以理解为如下:我们已经有了目前的架构。到此,相信大家对“go如何实现Redis读写分离”有了更深的了解,不妨来实际操作一番吧!这里是百云主机网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
本篇内容主要讲解“win10下FTP服务器搭建实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“win10下FTP服务器搭建实例分析”吧!(1)按【Win + R】快捷键打开运行对话框,输入“optionalf…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。