问题遇到的现象和发生背景
目前有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,能够快速相应。