diff --git a/docs/06_add_genai_gateway_capabilities_with_api_management/0601.md b/docs/06_add_genai_gateway_capabilities_with_api_management/0601.md new file mode 100644 index 000000000..6a4417695 --- /dev/null +++ b/docs/06_add_genai_gateway_capabilities_with_api_management/0601.md @@ -0,0 +1,215 @@ +--- +title: '1. Import an Azure OpenAI API and manage token consumption' +layout: default +nav_order: 1 +parent: 'Exercise 06: Add GenAI Gateway Capabilities with Azure API Management' +--- + +# Task 01 - Import an Azure OpenAI API and manage token consumption (20 minutes) + +## Introduction + +When developing GenAI applications, managing token consumption is crucial. The Azure OpenAI Service assigns a quota for your model deployments, expressed in tokens-per-minute (TPM), which is distributed across your model consumers. In the prototype you are building for Consoto Suites, you would like to be able to track token consumption by client IP address and ensure a single client cannot consume the entire TPM quota, leaving other clients with no option to take advantage of GenAI functionality. + +## Description + +In this task, you will import your Azure OpenAI service as an API in Azure API Management (APIM), implement a token limit policy, and emit token usage metrics to manage token consumption effectively. + +The key tasks are as follows: + +1. Import your Azure OpenAI Service resource as an API in Azure API Management. +2. Define a token limit policy to protect the API from overuse and to control Azure OpenAI costs. +3. Track token usage with an emit policy to log the consumed total, completion, and prompt tokens. + +## Success Criteria + +- You have imported your Azure OpenAI service resource as an API in Azure API Management. +- You have created a policy in APIM to limit token consumption to 500 TPM per client IP address. The policy should factor estimated prompt tokens into rate-limiting, and add consumed and remaining token headers to API responses. +- You are emitting token usage metrics to log the consumed total, completion, and prompt tokens using a policy defined in APIM. The customer dimensions should include "API ID" and "Client IP address." +- You have tested the API and policies within the Azure API Management service's APIs page in the [Azure portal](https://portal.azure.com/) and can view token metrics in your Application Insights instance. + - Use the following Kusto query to analyze token usage in Application Insights: + + ```kusto + customMetrics + | where timestamp > ago(1h) + | extend + ItemId = substring(itemId, 24), + ApiId = tostring(customDimensions['API ID']), + ClientIpAddress = tostring(customDimensions['Client IP address']) + | summarize + CompletionTokens = sumif(value, name == 'Completion Tokens'), + PromptTokens = sumif(value, name == 'Prompt Tokens'), + TotalTokens = sumif(value, name == 'Total Tokens') + by ItemId, ApiId, ClientIpAddress + ``` + + - View token usage in a chart using the following Kusto query: + + ```kusto + customMetrics + | where timestamp > ago(4h) + | extend ItemId = substring(itemId, 24) + | summarize TokenCount = sum(value) by ItemId, name + | order by ItemId + | render barchart with (kind=stacked) + ``` + +## Learning Resources + +- [Overview of generative AI gateway capabilities in Azure API Management](https://learn.microsoft.com/azure/api-management/genai-gateway-capabilities) +- [Import an Azure OpenAI API](https://learn.microsoft.com/azure/api-management/azure-openai-api-from-specification) +- [Policies in Azure API Management](https://learn.microsoft.com/azure/api-management/api-management-howto-policies) +- [How to set or edit Azure API Management policies](https://learn.microsoft.com/azure/api-management/set-edit-policies?tabs=form) +- [Limit Azure OpenAI API token usage](https://learn.microsoft.com/azure/api-management/azure-openai-token-limit-policy) +- [Emit metrics for consumption of Azure OpenAI tokens](https://learn.microsoft.com/azure/api-management/azure-openai-emit-token-metric-policy) + +## Solution + +
+Expand this section to view the solution + +- To import your Azure OpenAI service resource as an API in Azure API Management and define token limit and emit policies: + - Open a web browser and navigate to your Azure API Management resource in the [Azure portal](https://portal.azure.com/). +  - Expand the APIs menu on the API Management service page and select **APIs**. +  - On the **APIs** page, select **Add API** and select **Azure OpenAI Service** under **Create from Azure resource**. + + ![The Azure OpenAI Service panel is highlighted on the Add API page of the API Management Service.](../../media/Solution/0601-apim-create-api-from-azure-resource-openai-service.png) + +  - On the **Create from Azure OpenAI service** **Basics** tab, set the following values: + - **Azure OpenAI instance**: Choose the Azure OpenAI service resource you are using for this exercise. +    - **Azure OpenAI API version**: Accept the default value, which is the latest production-ready version. +    - **Display name**: Enter "Azure OpenAI API." +    - **Name**: This value with be automatically populated with "azure-openai-api," based on the display name you entered. You can edit this, but you should accept the generated value for this exercise. +    - **Description**: You can leave this blank or, optionally, enter a description, such as "Azure OpenAI API." +    - **Base URL**: This will be automatically created based on the **Name** of your API. Accept the generated value. +    - **Improve SDK compatibility**: Check this box. It will result in "/openai" being added to the end of the **Base URL** value. +    - **Products**: You can safely ignore this, as no products have been defined in your Azure API Management service. +  - Select **Next: Policies** and on the **Policies** tab, define the token limit and emitting policies. +  - To create a token limit policy, check the **Manage token consumption** box and set the following: +    - Enter a token limit of 500 tokens per minute (TPM). +    - Limit tokens by "IP address." +    - Check the box to include estimated prompt tokens. +    - Check the boxes to include the headers for the consumed and remaining tokens. + + ![Screenshot of the configuration specified for the Manage token consumption policy.](../../media/Solution/0601-apim-define-token-limit-policy.png) + +  - To use the Azure OpenAI emit token policy to log the consumed total, completion, and prompt tokens, check the **Track token usage** box and configure the following: +    - Choose the Application Insights instance associated with the resource group you are using for this exercise. +    - Add metric dimensions for **API ID** and **Client IP address**. + + ![Screenshot of the configuration specified for the Track token usage policy.](../../media/Solution/0601-apim-emit-token-policy.png) + +  - Select **Review + create**, then select **Create**. +  - The finished policies should look like the following in the policy editor: + + ```xml +  +    +      +      +      +        +        +      +      +      +    + ``` + +- To test the API, select **Azure OpenAI API** from the list of APIs on your API Management service's APIs page. +  - Select the **Test** tab, then select the **Creates a completion for the chat message** endpoint. +  - On the **Creates a completion for the chat message** page, enter the following under **Template parameters**: +    - **deployment-id**: Enter "gpt-4o" +    - **api-version**: Enter "2024-06-01" + + ![The Template parameters of deployment-id and api-version are set to gpt-4o and 2024-06-1, respectively.](../../media/Solution/0601-apim-api-test-template-parameters.png) + +  - Scroll down to the **Request body** section, ensure **Raw** is selected, and paste the following into the text box. + + ```json + { + "messages":[ + {"role": "system", "content": "You are a sarcastic unhelpful assistant."}, + {"role": "user", "content": "Tell me a story about AI."} + ] + } + ``` + + ![Screenshot of the Request body section, with the Raw radio button highlighted and the message body above highlighted in the body textbox.](../../media/Solution/0601-apim-test-request-body.png) + +  - Select **Send** at the bottom of the page. +  - Scroll to the page's **HTTP response** section and review the output on the **Message** tab. +    - In the headers, locate and review the headers added by your token limiting policy: +      - **consumed-tokens** +      - **remaining-tokens** +    - In the response body JSON, locate the "usage" element appended to the response. This element provides token usage data to help you monitor and manage your Azure OpenAI API consumption. It includes the number of tokens used for the completion and prompt and the total token consumption. + + ```json +   "usage": { +       "completion_tokens": 161, +       "prompt_tokens": 28, +       "total_tokens": 189 +   } + ``` + +  - Next, select **Send** several times rapidly until you see an HTTP response containing a **429 Too Many Requests** status code. + + The response header will look similar to the following: + + ```http + HTTP/1.1 429 Too Many Requests + content-length: 85 + content-type: application/json + date: Tue, 17 Sep 2024 00:05:47 GMT + remaining-tokens: 0 + request-context: appId=cid-v1:28064454-b368-42b8-a293-4e597441f43f + retry-after: 55 + vary: Origin + ``` + + The response body will contain the following: + + ```json +  { +      "statusCode": 429, +      "message": "Token limit is exceeded. Try again in 55 seconds." +  } + ``` + +- To view the output of your token emitting policy, you will use Application Insights. +  - From your API Management service in the [Azure portal](https://portal.azure.com/), expand the **Monitoring** menu and select **Application Insights**, then select your Application Insights instance from the list. +  - On the Application Insights page, expand the **Monitoring** menu and select **Logs**. +  - On the **Logs** page, execute the following Kusto query to look for records in the `customMetrics` table: + + ```kusto + customMetrics + | where timestamp > ago(1h) + | extend + ItemId = substring(itemId, 24), + ApiId = tostring(customDimensions['API ID']), + ClientIpAddress = tostring(customDimensions['Client IP address']) + | summarize + CompletionTokens = sumif(value, name == 'Completion Tokens'), + PromptTokens = sumif(value, name == 'Prompt Tokens'), + TotalTokens = sumif(value, name == 'Total Tokens') + by ItemId, ApiId, ClientIpAddress + ``` + + ![The results panel of the above query is displayed, showing token usage by ItemId, ApiId, and ClientIpAddress.](../../media/Solution/0601-app-insights-custom-metrics-results.png) + +  - You can also visualize token consumption using a chart with the following Kusto query: + + ```kusto + customMetrics + | where timestamp > ago(4h) + | extend + ItemId = substring(itemId, 24) + | summarize TokenCount = sum(value) by ItemId, name + | order by ItemId + | render barchart with (kind=stacked) + ``` + + ![Screenshot of the stacked bar chart produced by the above Kusto query, showing token usage by ItemId.](../../media/Solution/0601-app-insights-custom-metrics-chart.png) + +
diff --git a/docs/06_add_genai_gateway_capabilities_with_api_management/06_add_genai_gateway_capabilities_with_api_management.md b/docs/06_add_genai_gateway_capabilities_with_api_management/06_add_genai_gateway_capabilities_with_api_management.md index 8c341aa8d..df1c244c3 100644 --- a/docs/06_add_genai_gateway_capabilities_with_api_management/06_add_genai_gateway_capabilities_with_api_management.md +++ b/docs/06_add_genai_gateway_capabilities_with_api_management/06_add_genai_gateway_capabilities_with_api_management.md @@ -20,6 +20,7 @@ Upon completion of this lab, you will have gained the following skills: - Import an Azure OpenAI Service resource as an API in Azure API Management - Use APIM policies to manage token consumption and monitor token usage - Enable semantic caching using Azure Cache for Redis Enterprise and APIM +- Integrate APIM-managed APIs into GenAI applications ## Lab Duration diff --git a/media/Solution/0601-apim-api-test-template-parameters.png b/media/Solution/0601-apim-api-test-template-parameters.png new file mode 100644 index 000000000..ccd447a69 Binary files /dev/null and b/media/Solution/0601-apim-api-test-template-parameters.png differ diff --git a/media/Solution/0601-apim-create-api-from-azure-resource-openai-service.png b/media/Solution/0601-apim-create-api-from-azure-resource-openai-service.png new file mode 100644 index 000000000..80e456c3b Binary files /dev/null and b/media/Solution/0601-apim-create-api-from-azure-resource-openai-service.png differ diff --git a/media/Solution/0601-apim-define-token-limit-policy.png b/media/Solution/0601-apim-define-token-limit-policy.png new file mode 100644 index 000000000..460807e5e Binary files /dev/null and b/media/Solution/0601-apim-define-token-limit-policy.png differ diff --git a/media/Solution/0601-apim-emit-token-policy.png b/media/Solution/0601-apim-emit-token-policy.png new file mode 100644 index 000000000..9fe05885e Binary files /dev/null and b/media/Solution/0601-apim-emit-token-policy.png differ diff --git a/media/Solution/0601-apim-test-request-body.png b/media/Solution/0601-apim-test-request-body.png new file mode 100644 index 000000000..1f1ed717e Binary files /dev/null and b/media/Solution/0601-apim-test-request-body.png differ diff --git a/media/Solution/0601-app-insights-custom-metrics-chart.png b/media/Solution/0601-app-insights-custom-metrics-chart.png new file mode 100644 index 000000000..93e583eef Binary files /dev/null and b/media/Solution/0601-app-insights-custom-metrics-chart.png differ diff --git a/media/Solution/0601-app-insights-custom-metrics-results.png b/media/Solution/0601-app-insights-custom-metrics-results.png new file mode 100644 index 000000000..7495f03c7 Binary files /dev/null and b/media/Solution/0601-app-insights-custom-metrics-results.png differ