'vary' in APIM caching policies

1k Views Asked by At

I am learning Apim policies. In caching policies there is many elements of <vary-by.... In description of microsoft docs, it is mentionned that it caches by for example developer, query parameter... What does it mean exactly? Does this have a relation to refreshing values?

1

There are 1 best solutions below

5
Kai Walter On BEST ANSWER

I guess you are referring to https://learn.microsoft.com/en-us/azure/api-management/api-management-caching-policies#GetFromCache

<cache-lookup vary-by-developer="true | false" vary-by-developer-groups="true | false" caching-type="prefer-external | external | internal" downstream-caching-type="none | private | public" must-revalidate="true | false" allow-private-response-caching="@(expression to evaluate)">
  <vary-by-header>Accept</vary-by-header>
  <!-- should be present in most cases -->
  <vary-by-header>Accept-Charset</vary-by-header>
  <!-- should be present in most cases -->
  <vary-by-header>Authorization</vary-by-header>
  <!-- should be present when allow-private-response-caching is "true"-->
  <vary-by-header>header name</vary-by-header>
  <!-- optional, can repeated several times -->
  <vary-by-query-parameter>parameter name</vary-by-query-parameter>
  <!-- optional, can repeated several times -->
</cache-lookup>

By default the cache lookup would only use the URL path as a reference (the cache key) to find the cached item.

If you however wanted also to vary the cache lookup depending on a certain header or query parameter - with that extending the cache key - you would use <vary-by-header> or <vary-by-query-parameter> - so that for the same URL path responses are cached based on additional header and/or query parameters.

vary-by-developer or vary-by-developer-groups would extend the cache key with user or the group of the user assigned to the subscription key used - so that for the same URL path responses are cached based on who is calling the API operation.