Determine query cost in Gremlin.NET on Comos DB

I found it hard to find the query cost when using Gremlin.NET on Cosmos DB.

The only way I found until now is to analyse the exception text when a RequestRateTooLargeException is thrown.

Typically the most resource intensive queries throw these exceptions so it is interesting to analyse the query costs for these specific queries.

ServerError:
ActivityId : 3ae242d9-09bd-4870-8e0c-5f3b56941726
ExceptionType : RequestRateTooLargeException
ExceptionMessage :
 Message: {"Errors":["Request rate is large"]}
 ActivityId: 3f4d0f5c-a776-4f41-ab9c-ee9f08d64ca4, Request URI:, RequestStats:
 ResponseTime: 2018-03-26T06:57:58.4519869Z, StoreReadResult: StorePhysicalAddress: , GlobalCommittedLsn: 7393074, PartitionKeyRangeId: , IsValid: True, StatusCode: 0, IsGone: False, IsNotFound: False, IsInvalidPartition: False, RequestCharge: 0.38, ItemLSN: -1, ResourceType: Document, OperationType: Query
 , SDK: documentdb-dotnet-sdk/1.20.0 Host/64-bit MicrosoftWindowsNT/6.2.9200.0
Source : Microsoft.Azure.Documents.ClientMessage: {"Errors":["Request rate is large"]}
ActivityId: 3f4d0f5c-a776-4f41-ab9c-ee9f08d64ca4, Request URI: /, RequestStats:
ResponseTime: 2018-03-26T06:57:58.4519869Z, StoreReadResult: StorePhysicalAddress: , LSN: 7393075, GlobalCommittedLsn: 7393074, PartitionKeyRangeId: , IsValid: True, StatusCode: 0, IsGone: False, IsNotFound: False, IsInvalidPartition: False, RequestCharge: 0.38, ItemLSN: -1, ResourceType: Document, OperationType: Query
, SDK: documentdb-dotnet-sdk/1.20.0 Host/64-bit MicrosoftWindowsNT/6.2.9200.0
 BackendStatusCode : 429
 BackendActivityId : 3f4d0f5c-a776-4f41-ab9c-ee9f08d64ca4
 HResult : 0x80131500

I get the request charge out of the exception in the following way

   try
               {
                    var results = await _gremlinClient.SubmitAsync(query);
                    
                    return results;
                }
                catch (ResponseException r)
                {
                    if (r.Message.Contains("Request rate is large"))
                    {
                        Regex queryCostFinder = new Regex(@"RequestCharge: (\d{1,5}\.\d{1,4})");
                        var match = queryCostFinder.Match(r.Message);
                        queryCosts = double.Parse(match.Groups[1].Value);
                    }
                    else
                        throw;
                }

It helps but you rather see a property in Gremlin.NET that returns this value from the Http request charge header so you know it for all requests. I did not find a solution yet to fetch this header by using Gremlin.NET

Comments

PVApins said…
Using a Cambodia virtual phone number from PVApins is a game changer for Snapchat registration! I was able to bypass the usual SMS verification with my personal number and kept my privacy intact. It’s super easy to use and perfect for anyone looking to verify their Snapchat account without the hassle of exposing their phone number. Highly recommend it if you're looking for a secure way to complete the SMS verification process.
Visit us:- https://pvapins.com/?/EN

Popular posts from this blog

System.Net.Http dll version problems

SharePoint Survey Back Button

Azure table storage error: One of the request inputs is not valid