通过Redis实现一个异步请求-响应程序

server/2024/10/22 18:36:14/

在分布式系统中,经常需要不同的服务或组件之间进行通信和协作。传统的同步请求-响应模式虽然简单直观,但可能会导致阻塞和性能问题。为了解决这个问题,我们开发了一个基于 Redis 的异步请求-响应程序,实现了请求和响应的解耦,提高了系统的并发性和响应能力。

程序概述

该程序包含以下主要函数:

  1. SyncRequest(ctx context.Context, id, funcKey string, params interface{}, timeout int) (interface{}, error)
    • 用于发起请求,将请求信息存储在 Redis 中,并异步等待响应。
  2. GetCallInfoById(ctx context.Context, id string) (string, interface{}, error)
    • 根据请求 ID 从 Redis 中获取请求信息,供其他程序处理。
  3. PublishReplyData(ctx context.Context, id string, data interface{}) error
    • 将响应数据发布到 Redis 频道,供请求方接收。

通过这些函数,不同的程序可以实现异步的请求-响应模式,避免阻塞和提高并发性。

使用示例

假设我们有两个程序 A 和 B,需要进行异步通信。程序 A 发起请求,程序 B 处理请求并返回响应。

程序 A

package mainimport ("context""fmt""sagooiot/pkg/baseLogic"
)func main() {ctx := context.Background()id := "request_123" // 请求 IDfuncKey := "SomeFunction" // 函数键params := map[string]string{"key1": "value1", "key2": "value2"} // 请求参数// 发起异步请求response, err := baseLogic.SyncRequest(ctx, id, funcKey, params, 60)if err != nil {fmt.Println("Error:", err)return}// 处理响应fmt.Println("Response:", response)
}

在这个示例中,程序 A 调用 baseLogic.SyncRequest 发起一个异步请求,将请求信息存储在 Redis 中,并等待响应。超时时间设置为 60 秒。响应数据将被打印出来。

程序 B

package mainimport ("context""fmt""sagooiot/pkg/baseLogic"
)func main() {ctx := context.Background()id := "request_123" // 请求 ID// 从 Redis 获取请求信息funcKey, params, err := baseLogic.GetCallInfoById(ctx, id)if err != nil {fmt.Println("Error:", err)return}// 处理请求response := processRequest(funcKey, params)// 发布响应err = baseLogic.PublishReplyData(ctx, id, response)if err != nil {fmt.Println("Error:", err)return}
}func processRequest(funcKey string, params interface{}) interface{} {// 模拟处理请求的逻辑fmt.Println("Processing request:", funcKey, params)return "This is the response"
}

在这个示例中,程序 B 调用 baseLogic.GetCallInfoById 从 Redis 中获取请求信息。然后,它调用 processRequest 函数处理请求,并调用 baseLogic.PublishReplyData 将响应发布到 Redis 频道。

通过这种方式,程序 A 和程序 B 实现了异步的请求-响应模式。程序 A 发起请求后可以继续执行其他操作,而不会阻塞等待响应。程序 B 在收到请求信息后,可以在合适的时机处理并发布响应。两个程序之间通过 Redis 作为中介进行通信,实现了解耦和异步执行。

总结

该异步请求-响应程序提供了一种高效的方式,允许不同的服务或组件之间进行异步通信。通过利用 Redis 作为中介,请求和响应可以被解耦,提高了系统的并发性和响应能力。使用该程序可以避免阻塞,提高分布式系统的整体性能和可伸缩性。

以上程序,我们在企业级开源物联网系统SagooIoT产品中使用。


http://www.ppmy.cn/server/19757.html

相关文章

A. Desorting

time limit per test 1 second memory limit per test 256 megabytes input standard input output standard output Call an array a𝑎 of length n𝑛 sorted if a1≤a2≤…≤an−1≤an𝑎1≤𝑎2≤…≤𝑎&…

ECC(椭圆曲线密码学)和DH(迪菲-赫尔曼密钥交换)

目录 ECC(椭圆曲线密码学)和DH(迪菲-赫尔曼密钥交换) ECDHE和ECC在密码学领域

基于卷积神经网络的垃圾图像分类系统研究与实现

1.摘要 垃圾分类作为资源回收利用的重要环节之一, 可以有效地提高资源回收利用效率, 进一步减轻环境污染带来的危害. 随着现代工业逐步智能化, 传统的图像分类算法已经不能满足垃圾分拣设备的要求. 本文提出一种基于卷积神经网络的垃圾图像分类模型 (Garbage Classification Ne…

CC软件防火墙和WEB应用防火墙哪个好

本文将从CC软件防火墙的定义、原理、功能以及应用方面进行全面探讨,旨在加深对CC软件防火墙的理解,并推动网络安全意识的普及。以及WEB应用防火墙二者之间的对比。让用户更了解两个形态产品并作出选择。 第一部分:CC软件防火墙的定义和原理 …

Golang基础6-反射

反射 参考链接:Go 语言反射的实现原理 | Go 语言设计与实现 Go语言基础之反射 | 李文周的博客 https://juejin.cn/post/6844904177009688589 在程序运行期间对程序本身进行访问和修改的能力,程序在编译时,变量转换为内存地址,…

从头开始构建自己的 GPT 大型语言模型

图片来源: Tatev Aslanyan 一、说明 我们将使用 PyTorch 从头开始构建生成式 AI、大型语言模型——包括嵌入、位置编码、多头自注意、残差连接、层归一化,Baby GPT 是一个探索性项目,旨在逐步构建类似 GPT 的语言模型。在这个项目中&#xff…

go设计模式之工厂方法模式

工厂方法模式 什么是工厂方法模式 工厂方法模式是一种创建型设计模式,它定义了一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法使一个类的实例化推迟到其子类。 这个接口就是工厂接口,子类就是具体工厂类,而需要创…

如何快速找到python里面from_pretrained下载的模型位置(利用everything或fsearch)

问题: pipe DiffusionPipeline.from_pretrained("stabilityai/stable-diffusion-xl-base-1.0", use_safetensorsTrue, variant"fp16")经常在python中会下载预训练模型,然后在pycharm中使用ctrl鼠标点击也无法跳转位置 解决方法&a…