当前位置:网站首页>什么是“异步 Request-Reply”模式?编程如何实现?
什么是“异步 Request-Reply”模式?编程如何实现?
2022-07-22 00:35:00 【dotNET跨平台】
在某些情况下,WEB API 可能需要很长时间来处理请求,而客户端如果一直等待工作完成是不可行的,比如连接超时等。
这时,可以使用“异步 Request-Reply 模式”。
异步 Request-Reply 模式
异步 Request-Reply 模式是指:在后端处理需要是异步处理但前端仍需要明确响应的情况下,将后端处理与前端分离。
整体流程如下:
客户端应用程序对业务 API 进行调用,在后端触发长时间运行的操作;
API 立即返回响应。返回 HTTP 202 Accepted (接受) 状态码,确认已收到请求进行处理,响应包含一个标头,包含了客户端可以轮询状态的 API 地址,以检查长时间运行的操作的结果;;
客户端轮询这个状态 API,如果操作未完成,则返回 HTTP 202,否则返回 HTTP 200, 并包含实际的响应数据。
下面我们来演示如何在 ASP.NET Core 中实现。
Demo
我们用等待20秒模拟一个长时间 API 操作:
[HttpGet]
[Route("get")]
public async Task<IEnumerable<WeatherForecast>> Get()
{
await Task.Delay(20000);
var rng = new Random();
return Enumerable.Range(1, 5).Select(index => new WeatherForecast
{
Date = DateTime.Now.AddDays(index),
TemperatureC = rng.Next(-20, 55),
Summary = Summaries[rng.Next(Summaries.Length)]
})
.ToArray();
}
首先,我们创建一个新 API 操作:
[HttpGet]
[Route("async/get")]
public async Task<IActionResult> AsyncGet()
{
string id = Guid.NewGuid().ToString();
string responseValue = [email protected]"/status/{id}";
_cache.SetString(id, responseValue);
Task.Factory.StartNew(() =>
{
var result = Get().Result;
_cache.SetString(id + "_result", JsonConvert.SerializeObject(result));
});
return Accepted(responseValue);
}
具体作用就是把长时间交由 Task 执行,执行结果将放到分布式缓存中,然后立刻返回 HTTP 202 Accepted。
客户端不再访问原来的请求地址,而是使用此新地址:
然后,我们创建一个状态 API 用于轮询:
[HttpGet]
[Route("/status/{id}")]
public IActionResult Status(string id)
{
var result = _cache.GetString(id + "_result");
if (!string.IsNullOrEmpty(result))
{
return Ok(result);
}
return Accepted(_cache.GetString(id));
}
客户端根据 ID 进行轮询。
当操作还未完成时,继续返回 HTTP 202:
当操作完成时,返回分布式缓存中的结果:
结论
如果你的 API 有长时间运行的操作,应将轮询信息尽快地返回给调用方,以便他们可以检查进度。
想了解更多内容,请关注我的个人公众号”My IO“
边栏推荐
- Http实战之缓存、重定向
- The development of raspberry pie - the Internet cable connects raspberry pie and laptop directly - records the bitter process
- 第 3 章 处理数据
- ABAP语法基础3
- Pilot brother
- cookie和seesion的区别和联系
- Android 面试题:说一下 PendingIntent 和 Intent 的区别
- ASM Learning Series (II)
- Anomaly detection and self encoder (2)
- Développement d'ardunio - processus de fonctionnement des pompes
猜你喜欢
Final consistency distributed transaction TCC
Meituan two sides: redis five basic data structures?
MySQL tuning
1.监控概念
用 Redis 做一个可靠的延迟队列
Advanced C language: string function and Simulation Implementation
Ardunio开发——舵机控制
Redis data structure analysis (I)
To get a super practical small page - todollist
Cohérence finale transactions distribuées STC
随机推荐
Regular delete all elements after a specific character (case insensitive)
I met a 38K from Tencent two days ago, which showed me the ceiling of the foundation. Today I give it to you~
DOM -- event chain (capture target and capture)
面试遇到的问题
51单片机外设篇:按键
Final consistency distributed transaction TCC
7种 实现web实时消息推送的方案
What is the Zen of software testing? How to use it?
Simple message queue implementation nodejs + redis =mq
【机器学习】机器学习中到底需不需要进行样本平衡
CTF (dolls)
Full link voltage test: the dispute between shadow database and shadow table
9.zabbix-SNMP监控
通讯录(文件版本)
Redis数据结构分析(一)
Do you have to follow flush privileges after MySQL grant?
实习打怪之路:ES6中的Sym详解
软件测试禅道是什么?如何使用?
异常检测 and 自编码器(2)
Pytorch (IV) -- pytorch model definition