我刚刚运行了一些在Azure网站实例上报告其性能的代码;结果似乎有点偏。我重新运行了这个操作,看起来确实一致:System.Diagnostics.Stopwatch
执行时间为 12秒,实际操作时间超过三分钟 (至少3分16秒)。
Debug.WriteLine("Loading dataset in database ...");
var stopwatch = new Stopwatch();
stopwatch.Start();
ProcessDataset(CurrentDataSource.Database.Connection as SqlConnection, parser);
stopwatch.Stop();
Debug.WriteLine("Dataset loaded in database ({0}s)", stopwatch.Elapsed.Seconds);
return (short)stopwatch.Elapsed.Seconds;
此过程在WCF数据服务“操作”的上下文中运行,并在SQL数据库中生成测试数据(这不是生产代码)。具体来说,它:
System.Data.SqlClient.SqlBulkCopy
锁定空表并使用缓冲流加载它,该缓冲流通过文件系统从Azure Blob存储中检索数据集(2.4MB),对其进行解压缩(GZip,4.9MB膨胀)并对其进行解析( CSV,349996条记录,使用IDataReader
自定义TextFieldParser
进行解析,不少,不多;没有什么特别密集的事情,我认为这个操作主要是网络限制的。
知道时间减慢的原因吗?
注意:
SqlClient
以不同的方式衡量时间。答案 0 :(得分:2)
您使用了stopwatch.Elapsed.Seconds来获取总时间,但这是错误的。 Elapsed.Seconds是TimeSpan结构表示的时间间隔的秒分量。请尝试使用stopwatch.Elapsed.TotalSeconds。