enotek 2022-04-16 22:19
浏览 682
已结题

等待HttpClient.PostAsync()超时,或者返回时间很长。

问题遇到的现象和发生背景

目前有3个系统,分别是A,B,C。A系统会一直不断的同时调用B系统的不同API接口,有些相同接口一秒内调用几十次,参数不同或相同。
其中B系统的一个接口里面,会去调用C系统的接口,当A调用了B系统的这个接口,就会出现返回超时,或者返回时间几十秒,甚至几分钟,当然也有返回很快的情况。C系统没有问题,目前为了测试就做了一个转发的接口。下面代码速度就慢在client.PostAsync(Url, content)这里,log里输出来的dd时间差经常会有几十秒。B系统运行一段时间后,就会出现上面的情况,重启后一般就很快。

问题相关代码,请勿粘贴截图

//B系统接口:
[HttpPost]
public async Task callVeh(INPUT_P input)
{
if (input.state == "test")
{
//调用C系统
string url = "http://localhost:8866/getinfo"
}
}
//调用C系统 代码
using (var client = httpClient.CreateClient())
{
string responseBody = string.Empty;
client.DefaultRequestHeaders.Add("Method", "Post");
string jsonContent = message.ToString();
var content = new StringContent(jsonContent, Encoding.UTF8, "application/json");
content.Headers.Add("ContentType", "application/x-www-form-urlencoded");
DateTime dt_s = DateTime.Now;
_logger.LogInformation(dt_s + guid + ",bstarts6");
HttpResponseMessage response = await client.PostAsync(Url, content);//调用C系统
DateTime dt_e = DateTime.Now;
TimeSpan d = dt_e - dt_s;
_logger.LogInformation(dt_e + guid + ",bends7" + response.StatusCode + ";" + d);
}
// C系统接口
[HttpPost]
[AllowAnonymous]
public async Task getinfo()
{
string json = "{"test":"12345"}";
Infos Infos = JsonConvert.DeserializeObject(json);
return Infos;
}

运行结果及报错内容

Response:{"code":-4,"msg":"ERROR:The request was canceled due to the configured HttpClient.Timeout of 100 seconds elapsing.:A task was canceled.","data":null}

我的解答思路和尝试过的方法

我觉得是B系统被A系统一直在调用,会不会哪里阻塞了。因为如果重启B系统,再马上调用这个接口就没有问题。B系统运行一段时间后,就会出现上面的情况。感觉重启就是释放这种阻塞。但是B系统向外调用C系统,就这么一个地方,没有经常去调用。

我想要达到的结果

B调用C,能够快速相应。

  • 写回答

1条回答 默认 最新

  • enotek 2022-04-16 22:41
    关注

    如果把A系统关了,再用postman去调用b系统的这个接口,同样会很快。

    评论

报告相同问题?

问题事件

  • 系统已结题 4月24日
  • 创建了问题 4月16日

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog