0

我刚刚运行了一些代码来报告它在 Azure 网站实例上的性能;结果似乎有点不对劲。我重新运行了该操作,实际上它似乎是一致的: 对于一个实际花费超过分钟(至少3 分 16 秒)的操作,System.Diagnostics.Stopwatch执行时间为12 秒。

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 数据库中播种测试数据(这不是生产代码)。具体来说,它:

  1. 打开与 Azure SQL 数据库的连接,
  2. 禁用空约束,
  3. 用于System.Data.SqlClient.SqlBulkCopy锁定一个空表并使用缓冲流加载它,该缓冲流通过文件系统从 Azure Blob 存储中检索数据集 (2.4MB),解压缩它(GZip,4.9MB 膨胀)并解析它(CSV,349996 条记录,用自定义IDataReader使用TextFieldParser),
  4. 更新同一个表的列以设置一个共同的值,
  5. 重新启用空约束。

不多也不少;没有什么特别密集的事情发生,我认为该操作主要是网络绑定的。

知道为什么时间变慢了吗?

笔记:

  • 有趣的是,必须增加批量插入和更新命令的超时时间(设置为 5 分钟)。我读到默认是30秒,比报的12秒多;因此,我得出结论,以SqlClient不同的方式衡量时间。
  • 本地执行的报告似乎完全正确,尽管它始终更快(使用 LocalDB 为 4-6 秒),因此可能只是效果不明显。
4

1 回答 1

2

您使用 stopwatch.Elapsed.Seconds 来获取总时间,但这是错误的。Elapsed.Seconds 是由 TimeSpan 结构表示的时间间隔的秒分量。请改用 stopwatch.Elapsed.TotalSeconds。

于 2014-01-03T07:01:03.400 回答