当我试图调查一个真实项目中的问题时,我试图对托管在Azure web应用程序中的ASP.NET WebAPI的性能有一些了解。作为第一步,我使用默认模板在Visual Studio中创建了一个ASP.NET WebAPI项目,其中包含以下虚拟控制器:
public class ValuesController : ApiController
{
// GET api/values
public IEnumerable<string> Get()
{
return new string[] { "value1", "value2" };
}
// ...
}
我将该应用程序接口部署到D1 Azure web应用程序:
Shared infrastructure
1 GB memory
240 minutes/day compute
然后,我实现了一个简单、快速而又脏的客户端控制台应用程序:
var client = new RestClient("https://foo.azurewebsites.net/api/");
var request = new RestRequest("values", Method.GET);
var callsToExecute = 1000;
var totalElapsed = .0;
var responseCount = 0;
var totalSw = new Stopwatch();
totalSw.Start();
for (var i = 0; i < callsToExecute; i++)
{
var sw = new Stopwatch();
sw.Start();
client.ExecuteAsync(request, (r, h) => {
sw.Stop();
totalElapsed += sw.ElapsedMilliseconds;
responseCount++;
if (responseCount == callsToExecute) totalSw.Stop();
});
Thread.Sleep(10);
}
while(responseCount < callsToExecute)
{
Thread.Sleep(1000);
}
System.Console.WriteLine("Average time to response: " + totalElapsed / callsToExecute);
System.Console.WriteLine("Total duration: " + totalSw.ElapsedMilliseconds);
System.Console.ReadLine();
这个小的压力测试在10秒的时间范围内发送1000个请求,对于我来说,考虑到相对简单的控制器方法,这似乎不是很多。
结果是:
Average time to response: 5065.38 ms
Total duration: 23028 ms
我还尝试了一个使控制器方法异步的版本,它不会改变结果。使用WebClient
而不是RestSharp也不会改变结果。
根据资源监视器的数据,网络流量仅为2.5 kB/s左右。
当以较大的间隔(>1000ms)发送请求时,响应时间约为270ms,我认为这是一个合理的数量级。
我的问题:
{ "value1", "value2" }
1000次有多难?https://stackoverflow.com/questions/55111080
复制相似问题