Поиск затрат на единицу запроса для операций, выполняемых в Azure Cosmos DB для таблицы

ПРИМЕНИМО К: Таблица

Azure Cosmos DB поддерживает многие интерфейсы API, такие как SQL, MongoDB, Cassandra, Gremlin и Таблицы. У каждого API есть собственный набор операций базы данных, начиная от простого считывания и записи точек и заканчивая сложными запросами. Каждая операция базы данных потребляет системные ресурсы. Потребление зависит от сложности операции.

Стоимость всех операций базы данных нормализуется с помощью Azure Cosmos DB и выражается в единицах запроса (ЕЗ). Расходы на запрос выражается в единицах запроса, потребленных всеми операциями базы данных. ЕЗ можно считать единицей производительности, которая абстрагирует системные ресурсы (например, ЦП, операции ввода-вывода в секунду и память), необходимые для выполнения операций базы данных, поддерживаемых Azure Cosmos DB. Независимо от того, какой API вы используете для взаимодействия с контейнером Azure Cosmos DB, затраты всегда измеряются по единицам запросов. Независимо от типа операции базы данных (запись, чтение или запрос), затраты всегда измеряются в ЕЗ. Дополнительные сведения см. в статье Единицы запросов и рекомендации.

В этой статье представлены различные способы поиска потребления единиц запросов (ЕЗ) для любой операции, выполняемой с контейнером в Azure Cosmos DB для таблицы. Если вы используете другой API, ознакомьтесь со статьями ОБ API для MongoDB, API для Cassandra, API для Gremlin и API для NoSQL , чтобы узнать стоимость ЕЗ/с.

Использование пакета SDK для .NET

Единственный пакет SDK, который сейчас возвращает данные о расходах в ЕЗ для операций с таблицами, — это пакет SDK для .NET Standard. Объект TableResult предоставляет RequestCharge свойство, которое заполняется пакетом SDK при его использовании в Azure Cosmos DB для таблицы:

CloudTable tableReference = client.GetTableReference("table");
TableResult tableResult = tableReference.Execute(TableOperation.Insert(new DynamicTableEntity("partitionKey", "rowKey")));
if (tableResult.RequestCharge.HasValue) // would be false when using Azure Storage Tables
{
    double requestCharge = tableResult.RequestCharge.Value;
}

Дополнительные сведения см. в статье Краткое руководство. Создание приложения API для таблиц с помощью пакета SDK для .NET и Azure Cosmos DB.

Дальнейшие действия

Сведения об оптимизации потребления ЕЗ см. в следующих статьях: