返回顶部
首页 > 资讯 > 数据库 >go实现Redis读写分离示例详解
  • 640
分享到

go实现Redis读写分离示例详解

2024-04-02 19:04:59 640人浏览 独家记忆
摘要

目录我们为什么需要了解RESP协议?什么是RESP协议RESP协议规范如何使用该协议请求Redis使用Go编写Redis中间件实现读写分离总结我们为什么需要了解RESP协议? 本篇文章目的为探究RESP协议,而非编写读写

我们为什么需要了解RESP协议?

本篇文章目的为探究RESP协议,而非编写读写中间件,这点要清楚。

关于这个问题,我想通过一个实例来解释,我们编写Redis中间件,为什么需要了解RESP协议。

go实现Redis读写分离示例详解

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

我们尝试执行下该代码,并且输入redis-cli -p 8888进行连接。

go实现Redis读写分离示例详解

我们编写的服务器获取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

我们结合上述信息,可以画一张图。

go实现Redis读写分离示例详解

这就是协议的内容了。

而协议前缀+-:则要简单的多,直接跟数据即可,

例如:

+

+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读写分离示例详解

现在回头看看官网文档所提及的,该协议实现简单,直接可阅读,是不是理解的更加深刻了呢?

使用go编写Redis中间件实现读写分离

本篇暂不解释代码,而后单独开一篇谈论中间件代码。

实现该功能,其实本质上是区分命令是查询还是写入,若是查询,则直接转发到从库,而写入,则转发到主库即可,其架构图可以理解为如下:

go实现Redis读写分离示例详解

我们已经有了目前的架构。

主机端口密码角色
127.0.0.16379主库
127.0.0.17380从库

相关代码已经放到了 gitee.com/pdudo/golea…

我们来看看实际效果呢:

go实现Redis读写分离示例详解

总结

其实本篇文章核心的点是探究RESP协议,而我们使用go编写了一个软件,用于解析RESP协议,从而获取执行的命令,再根据命令属性,从而转发从库或者主库,以此来达到读写分离的效果。再次提及一下核心点是拆解RESP协议。

怎么样,好玩吧,动动你的小手指,快来试试吧。

以上就是go实现Redis读写分离示例详解的详细内容,更多关于go Redis读写分离的资料请关注我们其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: go实现Redis读写分离示例详解

本文链接: https://lsjlt.com/news/33931.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • go实现Redis读写分离示例详解
    目录我们为什么需要了解RESP协议?什么是RESP协议RESP协议规范如何使用该协议请求Redis使用go编写Redis中间件实现读写分离总结我们为什么需要了解RESP协议? 本篇文章目的为探究RESP协议,而非编写读写...
    99+
    2024-04-02
  • Redis如何实现数据库读写分离详解
    前言 Redis是一种NoSQL的文档数据库,通过key-value的结构存储在内存中,Redis读的速度是110000次/s,写的速度是81000次/s,性能很高,使用范围也很广。Redis是一个key-...
    99+
    2024-04-02
  • Redis主从实现读写分离
    前言 大家在工作中可能会遇到这样的需求,即Redis读写分离,目的是为了压力分散化。下面我将为大家介绍借助AWS的ELB实现读写分离,以写主读从为例。 实现 引用库文件 <!-- redis客...
    99+
    2022-06-04
    主从 Redis
  • redis读写分离怎么实现
    Redis读写分离可以通过以下几种方式实现:1. 主从复制(Master-Slave):将一个Redis实例作为主节点(Master...
    99+
    2023-09-06
    redis
  • SpringBoot详解如何实现读写分离
    目录前言1.项目引入依赖2.yml配置3.启动4.测试5.中间所遇到的问题前言 根据公司业务需求,项目需要读写分离,所以记录下读写分离的过程。 分为两个部分: 1.项目的读写分离。 ...
    99+
    2024-04-02
  • Redis实现读写分离有什么用
    这篇文章给大家分享的是有关Redis实现读写分离有什么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。读写分离Redis 通过副本,实现「主-从」运行模式,是故障切换的基石,用来提高系统运行可靠性。也支持读写分离...
    99+
    2023-06-27
  • SpringBoot详解MySQL如何实现读写分离
    目录前言一、主从数据源的配置二、数据源路由的配置三、数据源上下文环境四、切换注解和Aop配置五、用法以及测试六、总结前言 首先思考一个问题:在高并发的场景中,关于数据库都有哪些优化的...
    99+
    2024-04-02
  • SpringBoot+MyBatis+AOP实现读写分离的示例代码
    目录一、 MySQL 读写分离1.1、如何实现 MySQL 的读写分离? 1.2、MySQL 主从复制原理?1.3、MySQL 主从同步延时问题(精华)二、SpringBo...
    99+
    2024-04-02
  • SpringBoot+ShardingSphereJDBC实现读写分离详情
    目录1 概述2 环境3 一些基础理论3.1 读写分离3.2 主从复制3.3 数据库中间件简介4MySQL主从复制环境准备4.1 主库操作4.1.1 拉取镜像并创建容器运行4.1.2 ...
    99+
    2022-11-13
    SpringBoot读写分离 ShardingSphereJDBC读写分离
  • redis客户端实现高可用读写分离的方式详解
    背景 (1) redis单机的读写性能轻松上大几万,不过线上环境不会只部署光秃秃的一个节点,还是会配合 sentinel 再部署一个 slave作为高可用节点的; 但是standby...
    99+
    2024-04-02
  • Atlas实现读写分离
    该Atlas方案的实现需要基于MHA架构(而MHA架构需要 实现mysql主从复制且开启GTID特性) 常见方案介绍: Mysql-proxy(oracle)Mysql-router(oracle)Atla...
    99+
    2024-04-02
  • ProxySQL实现读写分离
    环境: 192.168.205.37: as ProxySQL server 192.168.205.47: as Master server 192.168.205.57: as Slave ser...
    99+
    2024-04-02
  • Java基于JNDI实现读写分离的示例代码
    目录一、JNDI数据源配置二、JNDI数据源使用三、web.xml配置四、spring-servlet.xml配置五、spring-db.xml配置六、log4j.propertie...
    99+
    2024-04-02
  • Sharding-JDBC自动实现MySQL读写分离的示例代码
    目录一、ShardingSphere和Sharding-JDBC概述1.1、ShardingSphere简介 1.2、Sharding-JDBC简介1.3、Sharding...
    99+
    2024-04-02
  • mysql+mycat实现读写分离
    centos7 master slave mycat1.6 client 192.168.41.10 192.168.41.11 192.168.41.12 192.168.41.13 ...
    99+
    2024-04-02
  • 一文解析Redis读写分离技术
    导读 云数据库Redis版不管主从版还是集群规格,replica作为备库不对外提供服务,只有在发生HA的时候,replica提升为master后才承担读写流量。这种架构读写请求都在master上完成...
    99+
    2024-04-02
  • SpringBoot整合sharding-jdbc实现分库分表与读写分离的示例
    目录一、前言二、数据库表准备三、整合四、docker-compose部署mysql主从五、本文案例demo源码一、前言 本文将基于以下环境整合sharding-jdbc实现分库分表与...
    99+
    2024-04-02
  • SpringBoot项目中如何实现MySQL读写分离详解
    目录1、MySQL主从复制1.1、介绍二进制日志:MySQL复制过程分成三步:1.2、主从库搭建1.2.1、主库配置1.2.2、从库配置1.3、坑位介绍1.3.1、UUID报错1.3...
    99+
    2024-04-02
  • SpringBoot+Mybatis-Plus实现mysql读写分离方案的示例代码
    引入mybatis-plus相关包,pom.xml文件 配置文件application.property增加多库配置 mysql 数据源配置 spring.datasource.primary.jdbc-u...
    99+
    2022-05-24
    SpringBoot Mybatis-Plus mysql 读写分离
  • Go读写锁操作方法示例详解
    目录引言读写锁有很多方法读操作写操作引言 前面讲到,在资源竞争的时候可以使用互斥锁,保证了资源访问的唯一性,但也降低了性能,仔细分析一下场景,如果只是读取数据,无论多少个gorout...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作