1

我只是做概念验证来衡量新的 Azure 存储客户端库 2.0 及其旧版 TableServiceQuery 的性能改进。

运行结果后,我很惊讶!而不是 Azure SCL 2.0 将获得性能提升。与 TableServiceQuery 相比,它的性能差了一倍。

这是我的代码:

var account = CloudStorageAccount.Parse(ConfigHelper.DataConnectionString);
var tableClient = account.CreateCloudTableClient();
var context = tableClient.GetTableServiceContext();
var table = tableClient.GetTableReference("User");

var sw = new Stopwatch();
sw.Start();
for (int i = 0; i < 100; i++)
{
    var query = context.CreateQuery<User>("User");
    var temp = (from item in query
                where item.PartitionKey == "12345"
                select item).First();
    temp.ToString();
}
sw.Stop();
Console.WriteLine("TableServiceQuery: " + sw.Elapsed);

sw.Reset();
sw.Start();
for (int i = 0; i < 100; i++)
{
    var query = new TableQuery<User>().Where(TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, "12345")).Take(1);
    var temp = table.ExecuteQuerySegmented(query, null).First();
    temp.ToString();
}
sw.Stop();
Console.WriteLine("TableQuery: " + sw.Elapsed);

结果是

TableServiceQuery: 00:00:13.8179295
TableQuery: 00:00:34.8782858

我尝试了几次,但新的 SCL 2.0 (TableQuery) 总是花费两倍以上的时间。我查询的“用户”表有大约百万条记录。

我的理解是新的 API 应该有很大的性能改进。有人请解释一下我的代码中是否遗漏了什么?或者我应该怎么做才能使新库具有更好的性能?

4

2 回答 2

1

此问题已在 SDK 2.0.6.1 中解决

于 2013-08-09T08:13:33.487 回答
0

如果您在 Windows Azure 角色上运行此测试,请确保在部署时禁用 Intellitrace。有关云服务的 Intellitrace 的更多信息,请参阅使用 IntelliTrace 和 Visual Studio 调试已发布的云服务一文。

于 2013-07-26T00:07:33.357 回答