Service | Microsoft Docs article | Related commit history on GitHub | Change details |
---|---|---|---|
active-directory-b2c | Technicalprofiles | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/active-directory-b2c/technicalprofiles.md | All types of technical profiles share the same concept. They start by reading th - Calls a REST API while sending parameters as InputClaims and getting information back as OutputClaims. - Creates or updates the user account. - Sends and verifies the multifactor authentication text message.-1. **Validation technical profiles**: A [self-asserted technical profile](self-asserted-technical-profile.md) can call [validation technical profiles](validation-technical-profile.md) to validate the data profiled by the user. +1. **Validation technical profiles**: A [self-asserted technical profile](self-asserted-technical-profile.md) can call [validation technical profiles](validation-technical-profile.md) to validate the data profiled by the user. Only self-asserted technical profiles can use validation technical profiles. 1. **Output claims**: Claims are returned back to the claims bag. You can use those claims in the next orchestrations step or output claims transformations. 1. **Output claims transformations**: After the technical profile is completed, Azure AD B2C runs output [claims transformations](claimstransformations.md). 1. **SSO session management**: Persists the technical profile's data to the session by using [SSO session management](custom-policy-reference-sso.md). |
active-directory-b2c | User Profile Attributes | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/active-directory-b2c/user-profile-attributes.md | Azure AD B2C directory user profile supports the [user resource type](/graph/api |creationType |String|If the user account was created as a local account for an Azure Active Directory B2C tenant, the value is LocalAccount or nameCoexistence. Read only.|No|No|Persisted, Output| |dateOfBirth |Date|Date of birth.|No|No|Persisted, Output| |department |String|The name for the department in which the user works. Max length 64.|Yes|No|Persisted, Output|-|displayName |String|The display name for the user. Max length 256. \< \> characters aren't allowed. | Yes|Yes|Persisted, Output| +|displayName |String|The display name for the user. Max length 256. | Yes|Yes|Persisted, Output| |facsimileTelephoneNumber<sup>1</sup>|String|The telephone number of the user's business fax machine.|Yes|No|Persisted, Output| |givenName |String|The given name (first name) of the user. Max length 64.|Yes|Yes|Persisted, Output| |jobTitle |String|The user's job title. Max length 128.|Yes|Yes|Persisted, Output| |
ai-services | Whats New | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-services/content-safety/whats-new.md | +## January 2024 ++### Content Safety SDK GA ++The Azure AI Content Safety service is now generally available through the following client library SDKs: ++- **C#**: [Package](https://www.nuget.org/packages/Azure.AI.ContentSafety) | [API reference](/dotnet/api/overview/azure/ai.contentsafety-readme?view=azure-dotnet) | [Samples](https://github.com/Azure-Samples/AzureAIContentSafety/tree/main/dotnet/1.0.0) +- **Python**: [Package](https://pypi.org/project/azure-ai-contentsafety/) | [API reference](/python/api/overview/azure/ai-contentsafety-readme?view=azure-python) | [Samples](https://github.com/Azure-Samples/AzureAIContentSafety/tree/main/python/1.0.0) +- **Java**: [Package](https://oss.sonatype.org/#nexus-search;quick~contentsafety) | [API reference](/java/api/overview/azure/ai-contentsafety-readme?view=azure-java-stable) | [Samples](https://github.com/Azure-Samples/AzureAIContentSafety/tree/main/java/1.0.0) +- **JavaScript**: [Package](https://www.npmjs.com/package/@azure-rest/ai-content-safety?activeTab=readme) | [API reference](https://www.npmjs.com/package/@azure-rest/ai-content-safety/v/1.0.0) | [Samples](https://github.com/Azure-Samples/AzureAIContentSafety/tree/main/js/1.0.0) + ## November 2023 ### Jailbreak risk and Protected material detection (preview) |
ai-services | Concept Retrieval Augumented Generation | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-services/document-intelligence/concept-retrieval-augumented-generation.md | monikerRange: '>=doc-intel-3.1.0' Retrieval-Augmented Generation (RAG) is a design pattern that combines a pretrained Large Language Model (LLM) like ChatGPT with an external data retrieval system to generate an enhanced response incorporating new data outside of the original training data. Adding an information retrieval system to your applications enables you to chat with your documents, generate captivating content, and access the power of Azure OpenAI models for your data. You also have more control over the data used by the LLM as it formulates a response. -The Document Intelligence [Layout model](concept-layout.md) is an advanced machine-learning based document analysis API. The Layout model offers a comprehensive solution for advanced content extraction and document structure analysis capabilities. With the Layout model, you can easily extract text and structural to divide large bodies of text into smaller, meaningful chunks based on semantic content rather than arbitrary splits. The extracted information can be conveniently outputted to Markdown format, enabling you to define your semantic chunking strategy based on the provided building blocks. +The Document Intelligence [Layout model](concept-layout.md) is an advanced machine-learning based document analysis API. The Layout model offers a comprehensive solution for advanced content extraction and document structure analysis capabilities. With the Layout model, you can easily extract text and structural elements to divide large bodies of text into smaller, meaningful chunks based on semantic content rather than arbitrary splits. The extracted information can be conveniently outputted to Markdown format, enabling you to define your semantic chunking strategy based on provided building blocks. :::image type="content" source="media/rag/azure-rag-processing.png" alt-text="Screenshot depicting semantic chunking with RAG using Azure AI Document Intelligence."::: Long sentences are challenging for natural language processing (NLP) application Text data chunking strategies play a key role in optimizing the RAG response and performance. Fixed-sized and semantic are two distinct chunking methods: -* **Fixed-sized chunking**. Most chunking strategies used in RAG today are based on fix-sized text segments known as chunks. Fixed-sized chunking is quick, easy, and effective with text that doesn't have a strong semantic structure such as logs and data. However it isn't recommended for text that requires semantic understanding and precise context. The fixed-size nature of the window can result in severing words, sentences, or paragraphs impeding comprehension and disrupt the flow of information and understanding. +* **Fixed-sized chunking**. Most chunking strategies used in RAG today are based on fix-sized text segments known as chunks. Fixed-sized chunking is quick, easy, and effective with text that doesn't have a strong semantic structure such as logs and data. However it isn't recommended for text that requires semantic understanding and precise context. The fixed-size nature of the window can result in severing words, sentences, or paragraphs impeding comprehension and disrupting the flow of information and understanding. -* **Semantic chunking**. This method divides the text into chunks based on semantic understanding. Division boundaries are focused on sentence subject and use significant computational algorithmically complex resources. However, it has the distinct advantage of maintaining semantic consistency within each chunk. It's useful for text summarization, sentiment analysis, and document classification tasks. +* **Semantic chunking**. This method divides the text into chunks based on semantic understanding. Division boundaries are focused on sentence subject and use significant computational algorithmically-complex resources. However, it has the distinct advantage of maintaining semantic consistency within each chunk. It's useful for text summarization, sentiment analysis, and document classification tasks. ## Semantic chunking with Document Intelligence Layout model Markdown is a structured and formatted markup language and a popular input for e * **Simplified processing**. You can parse different document types, such as digital and scanned PDFs, images, office files (docx, xlsx, pptx), and HTML, with just a single API call. -* **Scalability and AI quality**. The Layout model is highly scalable in Optical Character Recognition (OCR), table extraction, and [document structure analysis](concept-layout.md#document-layout-analysis). It supports [309 printed and 12 handwritten languages](language-support-ocr.md#model-id-prebuilt-layout) further ensuring high-quality results driven by AI capabilities. +* **Scalability and AI quality**. The Layout model is highly scalable in Optical Character Recognition (OCR), table extraction, and [document structure analysis](concept-layout.md#document-layout-analysis). It supports [309 printed and 12 handwritten languages](language-support-ocr.md#model-id-prebuilt-layout), further ensuring high-quality results driven by AI capabilities. * **Large learning model (LLM) compatibility**. The Layout model Markdown formatted output is LLM friendly and facilitates seamless integration into your workflows. You can turn any table in a document into Markdown format and avoid extensive effort parsing the documents for greater LLM understanding. -**Text image processed with Document Intelligence Studio and output to markdown using Layout model** +**Text image processed with Document Intelligence Studio and output to MarkDown using Layout model** :::image type="content" source="media/rag/markdown-text-output.png" alt-text="Screenshot of newspaper article processed by Layout model and outputted to Markdown."::: You can follow the [Document Intelligence Studio quickstart](quickstarts/try-doc * [Azure OpenAI on your data](../openai/concepts/use-your-data.md) enables you to run supported chat on your documents. Azure OpenAI on your data applies the Document Intelligence Layout model to extract and parse document data by chunking long text based on tables and paragraphs. You can also customize your chunking strategy using [Azure OpenAI sample scripts](https://github.com/microsoft/sample-app-aoai-chatGPT/tree/main/scripts) located in our GitHub repo. -* Azure AI Document Intelligence is now integrated with [LangChain](https://python.langchain.com/docs/integrations/document_loaders/azure_document_intelligence) as one of its document loaders. You can use it to easily load the data and output to Markdown format. This [notebook](https://github.com/microsoft/Form-Recognizer-Toolkit/blob/main/SampleCode/Python/sample_rag_langchain.ipynb) shows a simple demo for RAG pattern with Azure AI Document Intelligence as document loader and Azure Search as retriever in LangChain. +* Azure AI Document Intelligence is now integrated with [LangChain](https://python.langchain.com/docs/integrations/document_loaders/azure_document_intelligence) as one of its document loaders. You can use it to easily load the data and output to Markdown format. For more information, see our [sample code ](https://github.com/microsoft/Form-Recognizer-Toolkit/blob/main/SampleCode/Python/sample_rag_langchain.ipynb) that shows a simple demo for RAG pattern with Azure AI Document Intelligence as document loader and Azure Search as retriever in LangChain. * The chat with your data solution accelerator [code sample](https://github.com/Azure-Samples/chat-with-your-data-solution-accelerator) demonstrates an end-to-end baseline RAG pattern sample. It uses Azure AI Search as a retriever and Azure AI Document Intelligence for document loading and semantic chunking. |
ai-services | Gpt V Quickstart | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-services/openai/gpt-v-quickstart.md | description: Use this article to get started using Azure OpenAI to deploy and us -+ zone_pivot_groups: openai-quickstart-gpt-v * Learn more about these APIs in the [GPT-4 Turbo with Vision how-to guide](./gpt-v-quickstart.md) * [GPT-4 Turbo with Vision frequently asked questions](./faq.yml#gpt-4-turbo-with-vision)-* [GPT-4 Turbo with Vision API reference](https://aka.ms/gpt-v-api-ref) +* [GPT-4 Turbo with Vision API reference](https://aka.ms/gpt-v-api-ref) |
ai-services | Embeddings | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-services/openai/tutorials/embeddings.md | |
ai-services | Use Rest Api Programmatically | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-services/translator/document-translation/how-to-guides/use-rest-api-programmatically.md | To get started, you need: 1. **Resource Region**. Choose **Global** unless your business or application requires a specific region. If you're planning on using a [system-assigned managed identity](create-use-managed-identities.md) for authentication, choose a **geographic** region like **West US**. - 1. **Name**. Enter the name you have chosen for your resource. The name you choose must be unique within Azure. + 1. **Name**. Enter the name you chose for your resource. The name you choose must be unique within Azure. > [!NOTE] > Document Translation requires a custom domain endpoint. The value that you enter in the Name field will be the custom domain name parameter for your endpoint. To get started, you need: 1. Review the service terms and select **Create** to deploy your resource. - 1. After your resource has successfully deployed, select **Go to resource**. + 1. After your resource successfully deploys, select **Go to resource**. ### Retrieve your key and custom domain endpoint *Requests to the Translator service require a read-only key and custom endpoint to authenticate access. The custom domain endpoint is a URL formatted with your resource name, hostname, and Translator subdirectories and is available in the Azure portal. -1. If you've created a new resource, after it deploys, select **Go to resource**. If you have an existing Document Translation resource, navigate directly to your resource page. +1. If you created a new resource, after it deploys, select **Go to resource**. If you have an existing Document Translation resource, navigate directly to your resource page. 1. In the left rail, under *Resource Management*, select **Keys and Endpoint**. To get started, you need: Requests to the Translator service require a read-only key for authenticating access. -1. If you've created a new resource, after it deploys, select **Go to resource**. If you have an existing Document Translation resource, navigate directly to your resource page. +1. If you created a new resource, after it deploys, select **Go to resource**. If you have an existing Document Translation resource, navigate directly to your resource page. 1. In the left rail, under *Resource Management*, select **Keys and Endpoint**. 1. Copy and paste your key in a convenient location, such as *Microsoft Notepad*. 1. You paste it into the code sample to authenticate your request to the Document Translation service. You need to [**create containers**](../../../../storage/blobs/storage-quickstar The `sourceUrl` , `targetUrl` , and optional `glossaryUrl` must include a Shared Access Signature (SAS) token, appended as a query string. The token can be assigned to your container or specific blobs. *See* [**Create SAS tokens for Document Translation process**](create-sas-tokens.md). -* Your **source** container or blob must have designated **read** and **list** access. -* Your **target** container or blob must have designated **write** and **list** access. -* Your **glossary** blob must have designated **read** and **list** access. +* Your **source** container or blob must designate **read** and **list** access. +* Your **target** container or blob must designate **write** and **list** access. +* Your **glossary** blob must designate **read** and **list** access. > [!TIP] > The following headers are included with each Document Translation API request: "inputs": [ { "source": {- "sourceUrl": "https://my.blob.core.windows.net/source-en?sv=2019-12-12&st=2021-03-05T17%3A45%3A25Z&se=2021-03-13T17%3A45%3A00Z&sr=c&sp=rl&sig=SDRPMjE4nfrH3csmKLILkT%2Fv3e0Q6SWpssuuQl1NmfM%3D" + "sourceUrl": "{sourceSASUrl}" }, "targets": [ {- "targetUrl": "https://my.blob.core.windows.net/target-fr?sv=2019-12-12&st=2021-03-05T17%3A49%3A02Z&se=2021-03-13T17%3A49%3A00Z&sr=c&sp=wdl&sig=Sq%2BYdNbhgbq4hLT0o1UUOsTnQJFU590sWYo4BOhhQhs%3D", + "targetUrl": "{targetSASUrl}", "language": "fr" } ] The following headers are included with each Document Translation API request: ### Translate a specific document in a container * Specify `"storageType": "File"`-* If you aren't using a [**system-assigned managed identity**](create-use-managed-identities.md) for authentication, make sure you've created source URL & SAS token for the specific blob/document (not for the container) -* Ensure you've specified the target filename as part of the target URL ΓÇô though the SAS token is still for the container. +* If you aren't using a [**system-assigned managed identity**](create-use-managed-identities.md) for authentication, make sure you created source URL & SAS tokens for the specific blob/document (not for the container) +* Ensure you specified the target filename as part of the target URL ΓÇô though the SAS token is still for the container. * This sample request returns a single document translated into two target languages ```json The following headers are included with each Document Translation API request: { "storageType": "File", "source": {- "sourceUrl": "https://my.blob.core.windows.net/source-en/source-english.docx?sv=2019-12-12&st=2021-01-26T18%3A30%3A20Z&se=2021-02-05T18%3A30%3A00Z&sr=c&sp=rl&sig=d7PZKyQsIeE6xb%2B1M4Yb56I%2FEEKoNIF65D%2Fs0IFsYcE%3D" + "sourceUrl": "{sourceSASUrl}" }, "targets": [ {- "targetUrl": "https://my.blob.core.windows.net/target/try/Target-Spanish.docx?sv=2019-12-12&st=2021-01-26T18%3A31%3A11Z&se=2021-02-05T18%3A31%3A00Z&sr=c&sp=wl&sig=AgddSzXLXwHKpGHr7wALt2DGQJHCzNFF%2F3L94JHAWZM%3D", + "targetUrl": "{targetSASUrl}", "language": "es" }, {- "targetUrl": "https://my.blob.core.windows.net/target/try/Target-German.docx?sv=2019-12-12&st=2021-01-26T18%3A31%3A11Z&se=2021-02-05T18%3A31%3A00Z&sr=c&sp=wl&sig=AgddSzXLXwHKpGHr7wALt2DGQJHCzNFF%2F3L94JHAWZM%3D", + "targetUrl": "{targetSASUrl}", "language": "de" } ] The following headers are included with each Document Translation API request: "inputs": [ { "source": {- "sourceUrl": "https://myblob.blob.core.windows.net/source" + "sourceUrl": "{sourceSASUrl}" }, "targets": [ {- "targetUrl": "https://myblob.blob.core.windows.net/target", + "targetUrl": "{targetSASUrl}", "language": "es", "glossaries": [ {- "glossaryUrl": "https:// myblob.blob.core.windows.net/glossary/en-es.xlf", + "glossaryUrl": "{glossaryUrl/en-es.xlf}", "format": "xliff" } ] func main() { ### Brief overview -Cancel currently processing or queued job. Only documents for which translation hasn't started are canceled. +Cancel currently processing or queued job. Only documents for which translation isn't started are canceled. ### [C#](#tab/csharp) func main() { | 200 | OK | The request was successful. | | 400 | Bad Request | A required parameter is missing, empty, or null. Or, the value passed to either a required or optional parameter is invalid. A common issue is a header that is too long. | | 401 | Unauthorized | The request isn't authorized. Check to make sure your key or token is valid and in the correct region. When managing your subscription on the Azure portal, make sure you're using the **Translator** single-service resource _not_ the **Azure AI services** multi-service resource.-| 429 | Too Many Requests | You've exceeded the quota or rate of requests allowed for your subscription. | -| 502 | Bad Gateway | Network or server-side issue. May also indicate invalid headers. | +| 429 | Too Many Requests | You exceeded the quota or rate of requests allowed for your subscription. | +| 502 | Bad Gateway | Network or server-side issue. Can also indicate invalid headers. | ## Learn more |
ai-studio | Ai Resources | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/concepts/ai-resources.md | Title: Azure AI resource concepts description: This article introduces concepts about Azure AI resources.- |
ai-studio | Connections | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/concepts/connections.md | Title: Connections in Azure AI Studio description: This article introduces connections in Azure AI Studio- |
ai-studio | Content Filtering | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/concepts/content-filtering.md | Title: Azure AI Studio content filtering description: Learn about the content filtering capabilities of Azure OpenAI in Azure AI Studio.- |
ai-studio | Deployments Overview | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/concepts/deployments-overview.md | Title: Deploy models, flows, and web apps with Azure AI Studio description: Learn about deploying models, flows, and web apps with Azure AI Studio.- |
ai-studio | Evaluation Approach Gen Ai | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/concepts/evaluation-approach-gen-ai.md | Title: Evaluation of generative AI applications with Azure AI Studio description: Explore the broader domain of monitoring and evaluating large language models through the establishment of precise metrics, the development of test sets for measurement, and the implementation of iterative testing.- |
ai-studio | Evaluation Improvement Strategies | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/concepts/evaluation-improvement-strategies.md | Title: Harms mitigation strategies with Azure AI description: Explore various strategies for addressing the challenges posed by large language models and mitigating potential harms.- |
ai-studio | Evaluation Metrics Built In | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/concepts/evaluation-metrics-built-in.md | Title: Evaluation and monitoring metrics for generative AI description: Discover the supported built-in metrics for evaluating large language models, understand their application and usage, and learn how to interpret them effectively.- |
ai-studio | Rbac Ai Studio | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/concepts/rbac-ai-studio.md | Title: Role-based access control in Azure AI Studio description: This article introduces role-based access control in Azure AI Studio- |
ai-studio | Retrieval Augmented Generation | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/concepts/retrieval-augmented-generation.md | Title: Retrieval augmented generation in Azure AI Studio description: This article introduces retrieval augmented generation for use in generative AI applications.- |
ai-studio | Autoscale | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/autoscale.md | Title: Autoscale Azure AI limits description: Learn how you can manage and increase quotas for resources with Azure AI Studio.- |
ai-studio | Cli Install | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/cli-install.md | Title: Get started with the Azure AI CLI description: This article provides instructions on how to install and get started with the Azure AI CLI.- |
ai-studio | Commitment Tier | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/commitment-tier.md | Title: Commitment tier pricing for Azure AI description: Learn how to sign up for commitment tier pricing instead of pay-as-you-go pricing.- |
ai-studio | Configure Managed Network | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/configure-managed-network.md | Title: How to configure a managed network for Azure AI description: Learn how to configure a managed network for Azure AI- |
ai-studio | Configure Private Link | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/configure-private-link.md | Title: How to configure a private link for Azure AI description: Learn how to configure a private link for Azure AI- |
ai-studio | Connections Add | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/connections-add.md | Title: How to add a new connection in Azure AI Studio description: Learn how to add a new connection in Azure AI Studio- |
ai-studio | Costs Plan Manage | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/costs-plan-manage.md | Title: Plan and manage costs for Azure AI Studio description: Learn how to plan for and manage costs for Azure AI Studio by using cost analysis in the Azure portal.- |
ai-studio | Create Azure Ai Resource | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/create-azure-ai-resource.md | Title: How to create and manage an Azure AI resource description: This article describes how to create and manage an Azure AI resource- |
ai-studio | Create Manage Compute | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/create-manage-compute.md | Title: How to create and manage compute instances in Azure AI Studio description: This article provides instructions on how to create and manage compute instances in Azure AI Studio.- |
ai-studio | Create Manage Runtime | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/create-manage-runtime.md | Title: How to create and manage prompt flow runtimes description: Learn how to create and manage prompt flow runtimes in Azure AI Studio.- |
ai-studio | Create Projects | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/create-projects.md | Title: Create an Azure AI project in Azure AI Studio description: This article describes how to create an Azure AI Studio project.- |
ai-studio | Data Add | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/data-add.md | Title: How to add and manage data in your Azure AI project description: Learn how to add and manage data in your Azure AI project- |
ai-studio | Data Image Add | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/data-image-add.md | Title: 'Use your image data with Azure OpenAI Service' description: Use this article to learn about using your image data for image generation in Azure AI Studio.- Last updated 12/11/2023 + # Azure OpenAI on your data with images using GPT-4 Turbo with Vision (preview) |
ai-studio | Deploy Models Llama | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/deploy-models-llama.md | Title: How to deploy Llama 2 family of large language models with Azure AI Studio description: Learn how to deploy Llama 2 family of large language models with Azure AI Studio.- Last updated 12/11/2023 + |
ai-studio | Deploy Models Open | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/deploy-models-open.md | Title: How to deploy open models with Azure AI Studio description: Learn how to deploy open models with Azure AI Studio.- Last updated 12/11/2023 + # How to deploy large language models with Azure AI Studio |
ai-studio | Deploy Models Openai | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/deploy-models-openai.md | Title: How to deploy Azure OpenAI models with Azure AI Studio description: Learn how to deploy Azure OpenAI models with Azure AI Studio.- |
ai-studio | Evaluate Flow Results | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/evaluate-flow-results.md | Title: How to view evaluation results in Azure AI Studio description: This article provides instructions on how to view evaluation results in Azure AI Studio.- |
ai-studio | Evaluate Generative Ai App | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/evaluate-generative-ai-app.md | Title: How to evaluate with Azure AI Studio and SDK description: Evaluate your generative AI application with Azure AI Studio UI and SDK.- |
ai-studio | Evaluate Prompts Playground | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/evaluate-prompts-playground.md | Title: How to manually evaluate prompts in Azure AI Studio playground description: Quickly test and evaluate prompts in Azure AI Studio playground.- |
ai-studio | Fine Tune Model Llama | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/fine-tune-model-llama.md | Title: Fine-tune a Llama 2 model in Azure AI Studio description: Learn how to fine-tune a Llama 2 model in Azure AI Studio.- Last updated 12/11/2023 + |
ai-studio | Flow Bulk Test Evaluation | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/flow-bulk-test-evaluation.md | Title: Submit batch run and evaluate a flow description: Learn how to submit batch run and use built-in evaluation methods in prompt flow to evaluate how well your flow performs with a large dataset with Azure AI Studio.- |
ai-studio | Flow Deploy | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/flow-deploy.md | Title: Deploy a flow as a managed online endpoint for real-time inference description: Learn how to deploy a flow as a managed online endpoint for real-time inference with Azure AI Studio.- |
ai-studio | Flow Develop Evaluation | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/flow-develop-evaluation.md | Title: Develop an evaluation flow description: Learn how to customize or create your own evaluation flow tailored to your tasks and objectives, and then use in a batch run as an evaluation method in prompt flow with Azure AI Studio.- |
ai-studio | Flow Develop | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/flow-develop.md | Title: How to build with prompt flow description: This article provides instructions on how to build with prompt flow.- |
ai-studio | Flow Tune Prompts Using Variants | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/flow-tune-prompts-using-variants.md | Title: Tune prompts using variants description: Learn how to tune prompts using variants in Prompt flow with Azure AI Studio.- |
ai-studio | Generate Data Qa | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/generate-data-qa.md | Title: How to generate question and answer pairs from your source dataset description: This article provides instructions on how to generate question and answer pairs from your source dataset.- |
ai-studio | Index Add | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/index-add.md | Title: How to create vector indexes description: Learn how to create and use a vector index for performing Retrieval Augmented Generation (RAG).- |
ai-studio | Model Catalog | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/model-catalog.md | Title: Explore the model catalog in Azure AI Studio description: This article introduces foundation model capabilities and the model catalog in Azure AI Studio.- |
ai-studio | Models Foundation Azure Ai | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/models-foundation-azure-ai.md | Title: Explore Azure AI capabilities in Azure AI Studio description: This article introduces Azure AI capabilities in Azure AI Studio.- |
ai-studio | Monitor Quality Safety | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/monitor-quality-safety.md | Title: Monitor quality and safety of deployed applications description: Learn how to monitor quality and safety of deployed applications with Azure AI Studio.- |
ai-studio | Azure Open Ai Gpt 4V Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/azure-open-ai-gpt-4v-tool.md | Title: Azure OpenAI GPT-4 Turbo with Vision tool in Azure AI Studio description: This article introduces the Azure OpenAI GPT-4 Turbo with Vision tool for flows in Azure AI Studio.+ ---- Previously updated : 01/02/2024+ Last updated : 1/8/2024++++ -# Azure OpenAI GPT-4 Turbo with Vision tool (preview) in Azure AI studio +# Azure OpenAI GPT-4 Turbo with Vision tool in Azure AI Studio -Azure OpenAI GPT-4 Turbo with Vision tool enables you to leverage your AzureOpenAI GPT-4 Turbo with Vision model deployment to analyze images and provide textual responses to questions about them. ++The prompt flow *Azure OpenAI GPT-4 Turbo with Vision* tool enables you to use your Azure OpenAI GPT-4 Turbo with Vision model deployment to analyze images and provide textual responses to questions about them. ## Prerequisites -- Create a GPT-4 Turbo with Vision deployment+- An Azure subscription - <a href="https://azure.microsoft.com/free/cognitive-services" target="_blank">Create one for free</a>. +- Access granted to Azure OpenAI in the desired Azure subscription. ++ Currently, access to this service is granted only by application. You can apply for access to Azure OpenAI by completing the form at <a href="https://aka.ms/oai/access" target="_blank">https://aka.ms/oai/access</a>. Open an issue on this repo to contact us if you have an issue. - In AI studio, select **Deployments** from the left navigation pane and create a deployment by selecting model name: `gpt-4v`. +- An [Azure AI resource](../../how-to/create-azure-ai-resource.md) with a GPT-4 Turbo with Vision model deployed in one of the regions that support GPT-4 Turbo with Vision: Australia East, Switzerland North, Sweden Central, and West US. When you deploy from your project's **Deployments** page, select: `gpt-4` as the model name and `vision-preview` as the model version. ## Connection -Setup connections to provisioned resources in prompt flow. +Set up connections to provisioned resources in prompt flow. | Type | Name | API KEY | API Type | API Version | |-|-|-|-|-| Setup connections to provisioned resources in prompt flow. | Name | Type | Description | Required | ||-||-|-| connection | AzureOpenAI | the AzureOpenAI connection to be used in the tool | Yes | -| deployment\_name | string | the language model to use | Yes | -| prompt | string | The text prompt that the language model will use to generate its response. | Yes | -| max\_tokens | integer | the maximum number of tokens to generate in the response. Default is 512. | No | -| temperature | float | the randomness of the generated text. Default is 1. | No | -| stop | list | the stopping sequence for the generated text. Default is null. | No | -| top_p | float | the probability of using the top choice from the generated tokens. Default is 1. | No | -| presence\_penalty | float | value that controls the model's behavior with regard to repeating phrases. Default is 0. | No | -| frequency\_penalty | float | value that controls the model's behavior with regard to generating rare phrases. Default is 0. | No | +| connection | AzureOpenAI | The Azure OpenAI connection to be used in the tool. | Yes | +| deployment\_name | string | The language model to use. | Yes | +| prompt | string | Text prompt that the language model uses to generate its response. | Yes | +| max\_tokens | integer | Maximum number of tokens to generate in the response. Default is 512. | No | +| temperature | float | Randomness of the generated text. Default is 1. | No | +| stop | list | Stopping sequence for the generated text. Default is null. | No | +| top_p | float | Probability of using the top choice from the generated tokens. Default is 1. | No | +| presence\_penalty | float | Value that controls the model's behavior regarding repeating phrases. Default is 0. | No | +| frequency\_penalty | float | Value that controls the model's behavior regarding generating rare phrases. Default is 0. | No | ## Outputs |
ai-studio | Content Safety Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/content-safety-tool.md | Title: Content Safety tool for flows in Azure AI Studio description: This article introduces the Content Safety tool for flows in Azure AI Studio.- - ignite-2023-+ Last updated 11/15/2023--+++ # Content safety tool for flows in Azure AI Studio |
ai-studio | Embedding Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/embedding-tool.md | Title: Embedding tool for flows in Azure AI Studio description: This article introduces the Embedding tool for flows in Azure AI Studio.- - ignite-2023-+ Last updated 11/15/2023--+++ # Embedding tool for flows in Azure AI Studio |
ai-studio | Faiss Index Lookup Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/faiss-index-lookup-tool.md | Title: Faiss Index Lookup tool for flows in Azure AI Studio description: This article introduces the Faiss Index Lookup tool for flows in Azure AI Studio.- - ignite-2023-+ Last updated 11/15/2023--+++ # Faiss Index Lookup tool for flows in Azure AI Studio |
ai-studio | Llm Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/llm-tool.md | Title: LLM tool for flows in Azure AI Studio description: This article introduces the LLM tool for flows in Azure AI Studio.- - ignite-2023-+ Last updated 11/15/2023--+++ # LLM tool for flows in Azure AI Studio |
ai-studio | Prompt Flow Tools Overview | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/prompt-flow-tools-overview.md | Title: Overview of prompt flow tools in Azure AI Studio description: Learn about prompt flow tools that are available in Azure AI Studio.- Last updated 12/6/2023--+++ # Overview of prompt flow tools in Azure AI Studio The following table provides an index of tools in prompt flow. If existing tools | [LLM](./llm-tool.md) | Use Azure Open AI large language models (LLM) for tasks such as text completion or chat. | Default | [promptflow-tools](https://pypi.org/project/promptflow-tools/) | | [Prompt](./prompt-tool.md) | Craft a prompt by using Jinja as the templating language. | Default | [promptflow-tools](https://pypi.org/project/promptflow-tools/) | | [Python](./python-tool.md) | Run Python code. | Default | [promptflow-tools](https://pypi.org/project/promptflow-tools/) |-| [Azure OpenAI GPT-4 Turbo with Vision (preview)](./azure-open-ai-gpt-4v-tool.md) | Use AzureOpenAI GPT-4 Turbo with Vision model deployment to analyze images and provide textual responses to questions about them. | Default | [promptflow-tools](https://pypi.org/project/promptflow-tools/) | +| [Azure OpenAI GPT-4 Turbo with Vision](./azure-open-ai-gpt-4v-tool.md) | Use AzureOpenAI GPT-4 Turbo with Vision model deployment to analyze images and provide textual responses to questions about them. | Default | [promptflow-tools](https://pypi.org/project/promptflow-tools/) | | [Vector Index Lookup](./vector-index-lookup-tool.md) | Search text or a vector-based query from a vector index. | Default | [promptflow-vectordb](https://pypi.org/project/promptflow-vectordb/) | | [Content Safety (Text)](./content-safety-tool.md) | Use Azure AI Content Safety to detect harmful content. | Default | [promptflow-tools](https://pypi.org/project/promptflow-tools/) | | [Faiss Index Lookup](./faiss-index-lookup-tool.md) | Search a vector-based query from the Faiss index file. | Default | [promptflow-vectordb](https://pypi.org/project/promptflow-vectordb/) | |
ai-studio | Prompt Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/prompt-tool.md | Title: Prompt tool for flows in Azure AI Studio description: This article introduces the Prompt tool for flows in Azure AI Studio.- - ignite-2023-+ Last updated 11/15/2023--+++ # Prompt tool for flows in Azure AI Studio |
ai-studio | Python Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/python-tool.md | Title: Python tool for flows in Azure AI Studio description: This article introduces the Python tool for flows in Azure AI Studio.- -+ Last updated 11/15/2023--+++ # Python tool for flows in Azure AI Studio |
ai-studio | Serp Api Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/serp-api-tool.md | Title: Serp API tool for flows in Azure AI Studio description: This article introduces the Serp API tool for flows in Azure AI Studio.- - ignite-2023-+ Last updated 11/15/2023--+++ # Serp API tool for flows in Azure AI Studio |
ai-studio | Vector Db Lookup Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/vector-db-lookup-tool.md | Title: Vector DB Lookup tool for flows in Azure AI Studio description: This article introduces the Vector DB Lookup tool for flows in Azure AI Studio.- - ignite-2023-+ Last updated 11/15/2023--+++ # Vector DB Lookup tool for flows in Azure AI Studio |
ai-studio | Vector Index Lookup Tool | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow-tools/vector-index-lookup-tool.md | Title: Vector index lookup tool for flows in Azure AI Studio description: This article introduces the Vector index lookup tool for flows in Azure AI Studio.- - ignite-2023-+ Last updated 11/15/2023--+++ # Vector index lookup tool for flows in Azure AI Studio |
ai-studio | Prompt Flow | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/prompt-flow.md | Title: Prompt flow in Azure AI Studio description: This article introduces prompt flow in Azure AI Studio.- |
ai-studio | Quota | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/quota.md | Title: Manage and increase quotas for resources with Azure AI Studio description: This article provides instructions on how to manage and increase quotas for resources with Azure AI Studio.- |
ai-studio | Sdk Generative Overview | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/sdk-generative-overview.md | Title: Overview of the Azure AI Generative SDK packages description: This article provides overview of the Azure AI Generative SDK packages.- Last updated 12/15/2023 + # Overview of the Azure AI Generative SDK packages |
ai-studio | Sdk Install | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/sdk-install.md | Title: How to get started with the Azure AI SDK description: This article provides instructions on how to get started with the Azure AI SDK.- |
ai-studio | Simulator Interaction Data | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/simulator-interaction-data.md | Title: How to use the Azure AI simulator for interaction data description: This article provides instructions on how to use the Azure AI simulator for interaction data.- |
ai-studio | Troubleshoot Deploy And Monitor | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/troubleshoot-deploy-and-monitor.md | Title: How to troubleshoot your deployments and monitors in Azure AI Studio description: This article provides instructions on how to troubleshoot your deployments and monitors in Azure AI Studio.- |
ai-studio | Vscode Web | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/how-to/vscode-web.md | Title: Get started with Azure AI projects in VS Code (Web) description: This article provides instructions on how to get started with Azure AI projects in VS Code (Web).- |
ai-studio | Content Safety | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/quickstarts/content-safety.md | Title: Moderate text and images with content safety in Azure AI Studio description: Use this article to moderate text and images with content safety in Azure AI Studio.- |
ai-studio | Hear Speak Playground | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/quickstarts/hear-speak-playground.md | Title: Hear and speak with chat models in the Azure AI Studio playground description: Hear and speak with chat models in the Azure AI Studio playground.- |
ai-studio | Multimodal Vision | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/quickstarts/multimodal-vision.md | Title: Get started using GPT-4 Turbo with Vision on your images and videos in Azure AI Studio description: Get started using GPT-4 Turbo with Vision on your images and videos in Azure AI Studio.- Last updated 12/11/2023 + # Quickstart: Get started using GPT-4 Turbo with Vision on your images and videos in Azure AI Studio |
ai-studio | Playground Completions | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/quickstarts/playground-completions.md | Title: Generate product name ideas in the Azure AI Studio playground description: Use this article to generate product name ideas in the Azure AI Studio playground.- |
ai-studio | Region Support | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/reference/region-support.md | Title: Azure AI Studio feature availability across clouds regions description: This article lists Azure AI Studio feature availability across clouds regions.- Last updated 12/11/2023-+ + |
ai-studio | Deploy Chat Web App | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/tutorials/deploy-chat-web-app.md | Title: Deploy a web app for chat on your data in the Azure AI Studio playground description: Use this article to deploy a web app for chat on your data in the Azure AI Studio playground.- |
ai-studio | Deploy Copilot Ai Studio | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/tutorials/deploy-copilot-ai-studio.md | Title: Build and deploy a question and answer copilot with prompt flow in Azure AI Studio description: Use this article to build and deploy a question and answer copilot with prompt flow in Azure AI Studio- Last updated 11/15/2023 + # Tutorial: Build and deploy a question and answer copilot with prompt flow in Azure AI Studio |
ai-studio | Screen Reader | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/tutorials/screen-reader.md | Title: Using Azure AI Studio with a screen reader description: This tutorial guides you through using Azure AI Studio with a screen reader.- |
ai-studio | What Is Ai Studio | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/ai-studio/what-is-ai-studio.md | Title: What is AI Studio? description: Azure AI Studio brings together capabilities from across multiple Azure AI services. You can build generative AI applications on an enterprise-grade platform.- keywords: Azure AI services, cognitive |
aks | Access Control Managed Azure Ad | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/access-control-managed-azure-ad.md | -When you integrate Microsoft Entra ID with your AKS cluster, you can use [Conditional Access][aad-conditional-access] or Privileged Identity Management (PIM) for just-in-time requests to control access to your cluster. This article shows you how to enable Conditional Access and PIM on your AKS clusters. +When you integrate Microsoft Entra ID with your AKS cluster, you can use [Conditional Access][aad-conditional-access] or [Privileged Identity Management (PIM)][pim-configure] for just-in-time requests to control access to your cluster. This article shows you how to enable Conditional Access and PIM on your AKS clusters. > [!NOTE]-> Microsoft Entra Conditional Access and Privileged Identity Management are Microsoft Entra ID P1 or P2 capabilities requiring a Premium P2 SKU. For more on Microsoft Entra ID SKUs, see the [pricing guide][aad-pricing]. +> Microsoft Entra Conditional Access and Privileged Identity Management (PIM) are Microsoft Entra ID P1, P2 or Governance capabilities requiring a Premium P2 SKU. For more on Microsoft Entra ID licenses and SKUs, see [Microsoft Entra ID Governance licensing fundamentals][licensing-fundamentals] and [pricing guide][aad-pricing]. ## Before you begin Make sure the admin of the security group has given your account an *Active* ass <!-- LINKS - Internal --> [aad-conditional-access]: ../active-directory/conditional-access/overview.md+[pim-configure]: /entra/id-governance/privileged-identity-management/pim-configure +[licensing-fundamentals]: /entra/id-governance/licensing-fundamentals [az-aks-get-credentials]: /cli/azure/aks#az_aks_get_credentials [az-role-assignment-create]: /cli/azure/role/assignment#az_role_assignment_create [aad-assignments]: ../active-directory/privileged-identity-management/groups-assign-member-owner.md#assign-an-owner-or-member-of-a-group |
aks | Azure Ad Rbac | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/azure-ad-rbac.md | AKSDEV_ID=$(az ad user create \ --display-name "AKS Dev" \ --user-principal-name $AAD_DEV_UPN \ --password $AAD_DEV_PW \- --query objectId -o tsv) + --query id -o tsv) ``` 2. Add the user to the *appdev* group created in the previous section using the [`az ad group member add`][az-ad-group-member-add] command. AKSSRE_ID=$(az ad user create \ --display-name "AKS SRE" \ --user-principal-name $AAD_SRE_UPN \ --password $AAD_SRE_PW \- --query objectId -o tsv) + --query id -o tsv) # Add the user to the opssre Azure AD group az ad group member add --group opssre --member-id $AKSSRE_ID |
aks | Azure Csi Disk Storage Provision | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/azure-csi-disk-storage-provision.md | When you create an Azure disk for use with AKS, you can create the disk resource volumeMounts: - name: azure mountPath: /mnt/azure- volumeMounts volumes: - name: azure persistentVolumeClaim: |
aks | Azure Csi Files Storage Provision | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/azure-csi-files-storage-provision.md | A persistent volume claim (PVC) uses the storage class object to dynamically pro ```output NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE- my-azurefile Bound pvc-8436e62e-a0d9-11e5-8521-5a8664dc0477 10Gi RWX my-azurefile 5m + my-azurefile Bound pvc-8436e62e-a0d9-11e5-8521-5a8664dc0477 100Gi RWX my-azurefile 5m ``` ### Use the persistent volume |
aks | Concepts Network | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/concepts-network.md | This article introduces the core concepts that provide networking to your applic * [Network policies](#network-policies) ## Kubernetes basics+Kubernetes employs a virtual networking layer to manage access within and between your applications or their components. This involves the following key aspects: -To allow access to your applications or between application components, Kubernetes provides an abstraction layer to virtual networking. Kubernetes nodes connect to a virtual network, providing inbound and outbound connectivity for pods. The *kube-proxy* component runs on each node to provide these network features. +- **Kubernetes nodes and virtual network**: Kubernetes nodes are connected to a virtual network. This setup enables pods (basic units of deployment in Kubernetes) to have both inbound and outbound connectivity. -In Kubernetes: +- **Kube-proxy component**: Running on each node, kube-proxy is responsible for providing the necessary network features. -* *Services* logically group pods to allow for direct access on a specific port via an IP address or DNS name. -* *ServiceTypes* allow you to specify what kind of Service you want. -* You can distribute traffic using a *load balancer*. -* Layer 7 routing of application traffic can also be achieved with *ingress controllers*. -* You can *control outbound (egress) traffic* for cluster nodes. -* Security and filtering of the network traffic for pods is possible with *network policies*. +Regarding specific Kubernetes functionalities: -The Azure platform also simplifies virtual networking for AKS clusters. When you create a Kubernetes load balancer, you also create and configure the underlying Azure load balancer resource. As you open network ports to pods, the corresponding Azure network security group rules are configured. For HTTP application routing, Azure can also configure *external DNS* as new Ingress routes are configured. +- **Services**: These are used to logically group pods, allowing direct access to them through a specific IP address or DNS name on a designated port. +- **Service types**: This feature lets you specify the kind of Service you wish to create. +- **Load balancer**: You can use a load balancer to distribute network traffic evenly across various resources. +- **Ingress controllers**: These facilitate Layer 7 routing, which is essential for directing application traffic. +- **Egress traffic control**: Kubernetes allows you to manage and control outbound traffic from cluster nodes. +- **Network policies**: These policies enable security measures and filtering for network traffic in pods. ++In the context of the Azure platform: ++- Azure streamlines virtual networking for AKS (Azure Kubernetes Service) clusters. +- Creating a Kubernetes load balancer on Azure simultaneously sets up the corresponding Azure load balancer resource. +- As you open network ports to pods, Azure automatically configures the necessary network security group rules. +- Azure can also manage external DNS configurations for HTTP application routing as new Ingress routes are established. ## Services |
aks | Concepts Sustainable Software Engineering | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/concepts-sustainable-software-engineering.md | A service mesh deploys extra containers for communication, typically in a [sidec Sending and storing all logs from all possible sources (workloads, services, diagnostics, and platform activity) can increase storage and network traffic, which impacts costs and carbon emissions. -* Make sure you're collecting and retaining only the necessary log data to support your requirements. [Configure data collection rules for your AKS workloads](../azure-monitor/containers/container-insights-agent-config.md#data-collection-settings) and implement design considerations for [optimizing your Log Analytics costs](/azure/architecture/framework/services/monitoring/log-analytics/cost-optimization). +* Make sure you're collecting and retaining only the necessary log data to support your requirements. [Configure data collection rules for your AKS workloads](../azure-monitor/containers/container-insights-data-collection-configmap.md#data-collection-settings) and implement design considerations for [optimizing your Log Analytics costs](/azure/architecture/framework/services/monitoring/log-analytics/cost-optimization). ### Cache static data |
aks | Image Cleaner | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/image-cleaner.md | kubectl logs -n kube-system <worker-pod-name> -c trivy-scanner kubectl logs -n kube-system <worker-pod-name> -c remover ``` -- when `eraser-aks-xxxxx` was deleted, you can follow these steps to enable the [Azure Monitor add-on](./monitor-aks.md) and use the Container Insights pod log table to view historical pod logs.+- `eraser-aks-xxxxx` pod will be deleted in 10 minutes after work completion. You can follow these steps to enable the [Azure Monitor add-on](./monitor-aks.md) and use the Container Insights pod log table. After that, historical logs will be stored and you can review them even `eraser-aks-xxxxx` is deleted + 1. Ensure Azure Monitoring is enabled on your cluster. For detailed steps, see [Enable Container Insights on AKS clusters](../azure-monitor/containers/container-insights-enable-aks.md#existing-aks-cluster). 2. Get the Log Analytics resource ID using the [`az aks show`][az-aks-show] command. |
aks | Kubelogin Authentication | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/kubelogin-authentication.md | Title: Using Kubelogin with Azure Kubernetes Service (AKS) description: Learn about using Kubelogin to enable all of the supported Azure Active Directory authentication methods with Azure Kubernetes Service (AKS). + Last updated 11/28/2023- # Use Kubelogin with Azure Kubernetes Service (AKS) |
aks | Manage Ssh Node Access | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/manage-ssh-node-access.md | Title: Manage SSH access on Azure Kubernetes Service cluster nodes description: Learn how to configure SSH on Azure Kubernetes Service (AKS) cluster nodes. + Last updated 12/15/2023 To help troubleshoot any issues with SSH connectivity to your clusters nodes, yo [view-master-logs]: monitor-aks-reference.md#resource-logs [node-image-upgrade]: node-image-upgrade.md [az-aks-nodepool-upgrade]: /cli/azure/aks/nodepool#az-aks-nodepool-upgrade-[network-security-group-rules-overview]: concepts-security.md#azure-network-security-groups +[network-security-group-rules-overview]: concepts-security.md#azure-network-security-groups |
aks | Monitor Aks | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/monitor-aks.md | AKS generates the same kinds of monitoring data as other Azure resources that ar | Source | Description | |:|:| | Platform metrics | [Platform metrics](monitor-aks-reference.md#metrics) are automatically collected for AKS clusters at no cost. You can analyze these metrics with [metrics explorer](../azure-monitor/essentials/analyze-metrics.md) or use them for [metric alerts](../azure-monitor/alerts/alerts-types.md#metric-alerts). |-| Prometheus metrics | When you [enable metric scraping](../azure-monitor/containers/prometheus-metrics-enable.md) for your cluster, [Prometheus metrics](../azure-monitor/containers/prometheus-metrics-scrape-default.md) are collected by [Azure Monitor managed service for Prometheus](../azure-monitor/essentials/prometheus-metrics-overview.md) and stored in an [Azure Monitor workspace](../azure-monitor/essentials/azure-monitor-workspace-overview.md). Analyze them with [prebuilt dashboards](../azure-monitor/visualize/grafana-plugin.md#use-out-of-the-box-dashboards) in [Azure Managed Grafana](../managed-grafan). | +| Prometheus metrics | When you [enable metric scraping](../azure-monitor/containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) for your cluster, [Prometheus metrics](../azure-monitor/containers/prometheus-metrics-scrape-default.md) are collected by [Azure Monitor managed service for Prometheus](../azure-monitor/essentials/prometheus-metrics-overview.md) and stored in an [Azure Monitor workspace](../azure-monitor/essentials/azure-monitor-workspace-overview.md). Analyze them with [prebuilt dashboards](../azure-monitor/visualize/grafana-plugin.md#use-out-of-the-box-dashboards) in [Azure Managed Grafana](../managed-grafan). | | Activity logs | [Activity log](monitor-aks-reference.md) is collected automatically for AKS clusters at no cost. These logs track information such as when a cluster is created or has a configuration change. Send the [Activity log to a Log Analytics workspace](../azure-monitor/essentials/activity-log.md#send-to-log-analytics-workspace) to analyze it with your other log data. | | Resource logs | Control plane logs for AKS are implemented as resource logs. [Create a diagnostic setting](#aks-control-planeresource-logs) to send them to [Log Analytics workspace](../azure-monitor/logs/log-analytics-workspace-overview.md) where you can analyze and alert on them with log queries in [Log Analytics](../azure-monitor/logs/log-analytics-overview.md). | | Container insights | Container insights collects various logs and performance data from a cluster including stdout/stderr streams and stores them in a [Log Analytics workspace](../azure-monitor/logs/log-analytics-workspace-overview.md) and [Azure Monitor Metrics](../azure-monitor/essentials/data-platform-metrics.md). Analyze this data with views and workbooks included with Container insights or with [Log Analytics](../azure-monitor/logs/log-analytics-overview.md) and [metrics explorer](../azure-monitor/essentials/analyze-metrics.md). | The following Azure services and features of Azure Monitor can be used for extra | Service / Feature | Description | |:|:|-| [Container insights](../azure-monitor/containers/container-insights-overview.md) | Uses a containerized version of the [Azure Monitor agent](../azure-monitor/agents/agents-overview.md) to collect stdout/stderr logs, and Kubernetes events from each node in your cluster, supporting a [variety of monitoring scenarios for AKS clusters](../azure-monitor/containers/container-insights-overview.md#features-of-container-insights). You can enable monitoring for an AKS cluster when it's created by using [Azure CLI](../aks/learn/quick-kubernetes-deploy-cli.md), [Azure Policy](../azure-monitor/containers/container-insights-enable-aks-policy.md), Azure portal or Terraform. If you don't enable Container insights when you create your cluster, see [Enable Container insights for Azure Kubernetes Service (AKS) cluster](../azure-monitor/containers/container-insights-enable-aks.md) for other options to enable it.<br><br>Container insights store most of its data in a [Log Analytics workspace](../azure-monitor/logs/log-analytics-workspace-overview.md), and you'll typically use the same log analytics workspace as the [resource logs](monitor-aks-reference.md#resource-logs) for your cluster. See [Design a Log Analytics workspace architecture](../azure-monitor/logs/workspace-design.md) for guidance on how many workspaces you should use and where to locate them. | -| [Azure Monitor managed service for Prometheus](../azure-monitor/essentials/prometheus-metrics-overview.md) | [Prometheus](https://prometheus.io/) is a cloud-native metrics solution from the Cloud Native Compute Foundation and the most common tool used for collecting and analyzing metric data from Kubernetes clusters. Azure Monitor managed service for Prometheus is a fully managed Prometheus-compatible monitoring solution in Azure. If you don't enable managed Prometheus when you create your cluster, see [Collect Prometheus metrics from an AKS cluster](../azure-monitor/essentials/prometheus-metrics-enable.md) for other options to enable it.<br><br>Azure Monitor managed service for Prometheus stores its data in an [Azure Monitor workspace](../azure-monitor/essentials/azure-monitor-workspace-overview.md), which is [linked to a Grafana workspace](../azure-monitor/essentials/azure-monitor-workspace-manage.md#link-a-grafana-workspace) so that you can analyze the data with Azure Managed Grafana. | +| [Container insights](../azure-monitor/containers/container-insights-overview.md) | Uses a containerized version of the [Azure Monitor agent](../azure-monitor/agents/agents-overview.md) to collect stdout/stderr logs, and Kubernetes events from each node in your cluster, supporting a [variety of monitoring scenarios for AKS clusters](../azure-monitor/containers/container-insights-overview.md). You can enable monitoring for an AKS cluster when it's created by using [Azure CLI](../aks/learn/quick-kubernetes-deploy-cli.md), [Azure Policy](../azure-monitor/containers/container-insights-enable-aks-policy.md), Azure portal or Terraform. If you don't enable Container insights when you create your cluster, see [Enable Container insights for Azure Kubernetes Service (AKS) cluster](../azure-monitor/containers/container-insights-enable-aks.md) for other options to enable it.<br><br>Container insights store most of its data in a [Log Analytics workspace](../azure-monitor/logs/log-analytics-workspace-overview.md), and you'll typically use the same log analytics workspace as the [resource logs](monitor-aks-reference.md#resource-logs) for your cluster. See [Design a Log Analytics workspace architecture](../azure-monitor/logs/workspace-design.md) for guidance on how many workspaces you should use and where to locate them. | +| [Azure Monitor managed service for Prometheus](../azure-monitor/essentials/prometheus-metrics-overview.md) | [Prometheus](https://prometheus.io/) is a cloud-native metrics solution from the Cloud Native Compute Foundation and the most common tool used for collecting and analyzing metric data from Kubernetes clusters. Azure Monitor managed service for Prometheus is a fully managed Prometheus-compatible monitoring solution in Azure. If you don't enable managed Prometheus when you create your cluster, see [Collect Prometheus metrics from an AKS cluster](../azure-monitor/containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) for other options to enable it.<br><br>Azure Monitor managed service for Prometheus stores its data in an [Azure Monitor workspace](../azure-monitor/essentials/azure-monitor-workspace-overview.md), which is [linked to a Grafana workspace](../azure-monitor/essentials/azure-monitor-workspace-manage.md#link-a-grafana-workspace) so that you can analyze the data with Azure Managed Grafana. | | [Azure Managed Grafana](../managed-grafan#link-a-grafana-workspace) details on linking it to your Azure Monitor workspace so it can access Prometheus metrics for your cluster. | ## Metrics-Metrics play an important role in cluster monitoring, identifying issues, and optimizing performance in the AKS clusters. Platform metrics are captured using the out of the box metrics server installed in kube-system namespace, which periodically scrapes metrics from all Kubernetes nodes served by Kubelet. You should also enable Azure Managed Prometheus metrics to collect container metrics and Kubernetes object metrics, such as object state of Deployments. See [Collect Prometheus metrics from an AKS cluster](../azure-monitor/containers/prometheus-metrics-enable.md) to send data to Azure Managed service for Prometheus. +Metrics play an important role in cluster monitoring, identifying issues, and optimizing performance in the AKS clusters. Platform metrics are captured using the out of the box metrics server installed in kube-system namespace, which periodically scrapes metrics from all Kubernetes nodes served by Kubelet. You should also enable Azure Managed Prometheus metrics to collect container metrics and Kubernetes object metrics, such as object state of Deployments. See [Collect Prometheus metrics from an AKS cluster](../azure-monitor/containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) to send data to Azure Managed service for Prometheus. :::image type="content" source="media/monitor-aks/prometheus.png" alt-text="Screenshot of enabling Managed Prometheus for existing cluster." lightbox="media/monitor-aks/prometheus.png"::: Azure Monitor Container Insights provides a schema for container logs known as C - PodNamespace In addition, this schema is compatible with [Basic Logs](../azure-monitor/logs/basic-logs-configure.md?tabs=portal-1#set-a-tables-log-data-plan) data plan, which offers a low-cost alternative to standard analytics logs. The Basic log data plan lets you save on the cost of ingesting and storing high-volume verbose logs in your Log Analytics workspace for debugging, troubleshooting, and auditing, but not for analytics and alerts. For more information, see [Manage tables in a Log Analytics workspace](../azure-monitor/logs/manage-logs-tables.md?tabs=azure-portal).-ContainerLogV2 is the recommended approach and is the default schema for customers onboarding container insights with Managed Identity Auth using ARM, Bicep, Terraform, Policy, and Azure portal. For more information about how to enable ContainerLogV2 through either the cluster's Data Collection Rule (DCR) or ConfigMap, see [Enable the ContainerLogV2 schema](../azure-monitor/containers/container-insights-logging-v2.md?tabs=configure-portal#enable-the-containerlogv2-schema-1). +ContainerLogV2 is the recommended approach and is the default schema for customers onboarding container insights with Managed Identity Auth using ARM, Bicep, Terraform, Policy, and Azure portal. For more information about how to enable ContainerLogV2 through either the cluster's Data Collection Rule (DCR) or ConfigMap, see [Enable the ContainerLogV2 schema](../azure-monitor/containers/container-insights-logs-schema.md?tabs=configure-portal#enable-the-containerlogv2-schema). ## Visualization |
aks | Node Access | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/node-access.md | Title: Connect to Azure Kubernetes Service (AKS) cluster nodes description: Learn how to connect to Azure Kubernetes Service (AKS) cluster nodes for troubleshooting and maintenance tasks.- Previously updated : 12/20/2023+ Last updated : 01/08/2024 #Customer intent: As a cluster operator, I want to learn how to connect to virtual machines in an AKS cluster to perform maintenance or troubleshoot a problem. -Throughout the lifecycle of your Azure Kubernetes Service (AKS) cluster, you might need to access an AKS node. This access could be for maintenance, log collection, or troubleshooting operations. You can securely authenticate against AKS Linux and Windows nodes using SSH, and you can also [connect to Windows Server nodes using remote desktop protocol (RDP)][aks-windows-rdp]. For security reasons, the AKS nodes aren't exposed to the internet. To connect to the AKS nodes, you use `kubectl debug` or the private IP address. +Throughout the lifecycle of your Azure Kubernetes Service (AKS) cluster, you eventually need to directly access an AKS node. This access could be for maintenance, log collection, or troubleshooting operations. -This article shows you how to create a connection to an AKS node and update the SSH key on an existing AKS cluster. +You access a node through authentication, which methods vary depending on your Node OS and method of connection. You securely authenticate against AKS Linux and Windows nodes using SSH. Alternatively, for Windows Servers you can also connect to Windows Server nodes using the [remote desktop protocol (RDP)][aks-windows-rdp]. ++For security reasons, AKS nodes aren't exposed to the internet. Instead, to connect directly to any AKS nodes, you need to use either `kubectl debug` or the host's private IP address. ++This guide shows you how to create a connection to an AKS node and update the SSH key of your AKS cluster. ## Before you begin -This article assumes you have an SSH key. If not, you can create an SSH key using [macOS or Linux][ssh-nix] or [Windows][ssh-windows], to know more refer [Manage SSH configuration][manage-ssh-node-access]. Make sure you save the key pair in an OpenSSH format, other formats like .ppk aren't supported. +To follow along the steps, you need to use Azure CLI that supports version 2.0.64 or later. Run `az --version` to check the version. If you need to install or upgrade, see [Install Azure CLI][install-azure-cli]. ++Complete these steps if you don't have an SSH key. Create an SSH key depending on your Node OS Image, for [macOS and Linux][ssh-nix], or [Windows][ssh-windows]. Make sure you save the key pair in the OpenSSH format, avoid unsupported formats such as `.ppk`. Next, refer to [Manage SSH configuration][manage-ssh-node-access] to add the key to your cluster. ++## Linux and macOS -You also need the Azure CLI version 2.0.64 or later installed and configured. Run `az --version` to find the version. If you need to install or upgrade, see [Install Azure CLI][install-azure-cli]. +Linux and macOS users can SSH to access their node using `kubectl debug` or their private IP Address. Windows users should skip to the Windows Server Proxy section for a workaround to SSH via proxy. -## Create an interactive shell connection to a Linux node using kubectl +### SSH using kubectl debug -To create an interactive shell connection to a Linux node, use the `kubectl debug` command to run a privileged container on your node. +To create an interactive shell connection, use the `kubectl debug` command to run a privileged container on your node. 1. To list your nodes, use the `kubectl get nodes` command: ```bash kubectl get nodes -o wide ```- - The following example resembles output from the command: - ++ Sample output: + ```output NAME STATUS ROLES AGE VERSION INTERNAL-IP EXTERNAL-IP OS-IMAGE aks-nodepool1-37663765-vmss000000 Ready agent 166m v1.25.6 10.224.0.33 <none> Ubuntu 22.04.2 LTS To create an interactive shell connection to a Linux node, use the `kubectl debu aksnpwin000000 Ready agent 160m v1.25.6 10.224.0.62 <none> Windows Server 2022 Datacenter ``` -2. Use the `kubectl debug` command to run a container image on the node to connect to it. The following command starts a privileged container on your node and connects to it. +2. Use the `kubectl debug` command to start a privileged container on your node and connect to it. ```bash kubectl debug node/aks-nodepool1-37663765-vmss000000 -it --image=mcr.microsoft.com/cbl-mariner/busybox:2.0 ``` - The following example resembles output from the command: + Sample output: ```output Creating debugging pod node-debugger-aks-nodepool1-37663765-vmss000000-bkmmx with container debugger on node aks-nodepool1-37663765-vmss000000. If you don't see a command prompt, try pressing enter. root@aks-nodepool1-37663765-vmss000000:/# ```- - This privileged container gives access to the node. - ++ You now have access to the node through a privileged container as a debugging pod. + > [!NOTE] > You can interact with the node session by running `chroot /host` from the privileged container. -### Remove Linux node access +### Exit kubectl debug mode -When you're done with a debugging pod, enter the `exit` command to end the interactive shell session. After the interactive container session closes, delete the pod used for access with `kubectl delete pod`. +When you're done with your node, enter the `exit` command to end the interactive shell session. After the interactive container session closes, delete the debugging pod used with `kubectl delete pod`. ```bash kubectl delete pod node-debugger-aks-nodepool1-37663765-vmss000000-bkmmx ```-## Create an interactive shell connection to a node using private IP -If you don't have access to the Kubernetes API, you can get access to properties such as ```Node IP``` and ```Node Name``` through the AKS Agentpool Preview API(preview version 07-02-2023 or above) to troubleshoot node-specific issues in your AKS node pools. For convenience, we also expose the public IP if the node has a public IP assigned. However in order to SSH into the node, you need to be in the cluster's virtual network. +## Private IP Method -1. To get the private IP via CLI, use az cli version 2.53 or above with aks-preview extension installed. +If you don't have access to the Kubernetes API, you can get access to properties such as ```Node IP``` and ```Node Name``` through the [AKS Agent Pool Preview API][agent-pool-rest-api] (preview version 07-02-2023 or above) to troubleshoot node-specific issues in your AKS node pools. -```bash - az aks machine list --resource-group myResourceGroup --cluster-name myAKSCluster --nodepool-name nodepool1 -o table - - ``` --The following example resembles output from the command: -- ```output - Name Ip - -- -aks-nodepool1-33555069-vmss000000 10.224.0.5,family:IPv4; -aks-nodepool1-33555069-vmss000001 10.224.0.6,family:IPv4; -aks-nodepool1-33555069-vmss000002 10.224.0.4,family:IPv4; -``` -To target a specific node inside the nodepool, use this command: +### Create an interactive shell connection to a node using the IP address -```bash - az aks machine show --cluster-name myAKScluster --nodepool-name nodepool1 -g myResourceGroup --machine-name aks-nodepool1-33555069-vmss000000 -o table - - ``` - The following example resembles output from the command: +For convenience, the nodepools are exposed when the node has a public IP assigned. However, you need to be in the cluster's virtual network to SSH into the node. -```output - Name Ip - -- -aks-nodepool1-33555069-vmss000000 10.224.0.5,family:IPv4; - ``` +1. To get the private IP, use the `machine list` to show all your VMs. -2. Use the private IP to SSH into the node. [Azure Bastion][azure-bastion] also provides you with information for securely connecting to virtual machines via private IP address. Make sure that you configure an Azure Bastion host for the virtual network in which the VM resides. + ```bash + az aks machine list --resource-group myResourceGroup --cluster-name myAKSCluster --nodepool-name nodepool1 -o table + ``` -```bash -ssh azureuser@10.224.0.33 -``` + Sample output: -## Create the SSH connection to a Windows node + ```output + Name Ip + -- + aks-nodepool1-33555069-vmss000000 10.224.0.5,family:IPv4; + aks-nodepool1-33555069-vmss000001 10.224.0.6,family:IPv4; + aks-nodepool1-33555069-vmss000002 10.224.0.4,family:IPv4; + ``` + To target a specific node inside the nodepool, add a `--machine-name` flag: ++ ```bash + az aks machine show --cluster-name myAKScluster --nodepool-name nodepool1 -g myResourceGroup --machine-name aks-nodepool1-33555069-vmss000000 -o table + ``` + Sample output: -At this time, you can't connect to a Windows Server node directly by using `kubectl debug`. Instead, you need to first connect to another node in the cluster, then connect to the Windows Server node from that node using SSH. Alternatively, you can [connect to Windows Server nodes using remote desktop protocol (RDP) connections][aks-windows-rdp] instead of using SSH or use SSH with 'machines API' presented at the start of this document. + ```output + Name Ip + -- + aks-nodepool1-33555069-vmss000000 10.224.0.5,family:IPv4; + ``` -To connect to another node in the cluster, use the `kubectl debug` command. For more information, see the Linux section. +2. SSH using your private IP address to access your node. ++ ```bash + ssh azureuser@10.224.0.33 + ``` -To create the SSH connection to the Windows Server node from another node, use the SSH keys provided when you created the AKS cluster and the internal IP address of the Windows Server node. +3. Optionally, you can test with Azure Bastion. Follow these steps to set up [Azure Bastion][azure-bastion] to test your connection to your virtual machines using a private IP address. Make sure that the Azure Bastion is hosted in the same virtual network as your VM. ++## Windows Server proxy connection ++Follow these steps as a workaround to connect with SSH on a Windows Server node. ++### Create a proxy server ++At this time, you can't connect to a Windows Server node directly by using `kubectl debug`. Instead, you need to first connect to another node in the cluster with `kubectl`, then connect to the Windows Server node from that node using SSH. Alternatively, you can connect to Windows Server nodes using [remote desktop protocol (RDP) connections][aks-windows-rdp]. ++To connect to another node in the cluster, use the `kubectl debug` command. For more information, follow the above steps in the kubectl section. Create an SSH connection to the Windows Server node from another node, and use the SSH keys provided when you created the AKS cluster and the internal IP address of the Windows Server node. > [!IMPORTANT] >-> The following steps for creating the SSH connection to the Windows Server node from another node can only be used if you created your AKS cluster using the Azure CLI and the `--generate-ssh-keys` parameter. AKS Update command can also be used to manage, create SSH keys on an existing AKS cluster. For more information refer [Manage SSH configuration][manage-ssh-node-access]. +> The following steps for creating the SSH connection to the Windows Server node from another node can only be used if you created your AKS cluster using the Azure CLI and the `--generate-ssh-keys` parameter. The AKS Update command can also be used to manage, create SSH keys on an existing AKS cluster. For more information, see [manage SSH node access][manage-ssh-node-access]. ++Finish the prior steps to use kubectl debug, then return to this section, as you need to run the `kubectl debug` in your proxy. 1. Open a new terminal window and use the `kubectl get pods` command to get the name of the pod started by `kubectl debug`. To create the SSH connection to the Windows Server node from another node, use t kubectl get pods ``` - The following example resembles output from the command: + Sample output: ```output NAME READY STATUS RESTARTS AGE node-debugger-aks-nodepool1-37663765-vmss000000-bkmmx 1/1 Running 0 21s ``` - In the previous example, *node-debugger-aks-nodepool1-37663765-vmss000000-bkmmx* is the name of the pod started by `kubectl debug`. + In the sample output, *node-debugger-aks-nodepool1-37663765-vmss000000-bkmmx* is the name of the pod started by `kubectl debug`. 2. Use the `kubectl port-forward` command to open a connection to the deployed pod: To create the SSH connection to the Windows Server node from another node, use t kubectl port-forward node-debugger-aks-nodepool1-37663765-vmss000000-bkmmx 2022:22 ``` - The following example resembles output from the command: + Sample output: ```output Forwarding from 127.0.0.1:2022 -> 22 To create the SSH connection to the Windows Server node from another node, use t kubectl get no -o custom-columns=NAME:metadata.name,'INTERNAL_IP:status.addresses[?(@.type == \"InternalIP\")].address' ``` - The following example resembles output from the command: + Sample output: ```output NAME INTERNAL_IP To create the SSH connection to the Windows Server node from another node, use t ssh -o 'ProxyCommand ssh -p 2022 -W %h:%p azureuser@127.0.0.1' azureuser@10.224.0.62 ``` - The following example resembles output from the command: + Sample output: ```output The authenticity of host '10.224.0.62 (10.224.0.62)' can't be established. ECDSA key fingerprint is SHA256:1234567890abcdefghijklmnopqrstuvwxyzABCDEFG. Are you sure you want to continue connecting (yes/no)? yes- - [...] - - Microsoft Windows [Version 10.0.17763.1935] - (c) 2018 Microsoft Corporation. All rights reserved. - - azureuser@aksnpwin000000 C:\Users\azureuser> ``` > [!NOTE] To create the SSH connection to the Windows Server node from another node, use t ## Next steps -If you need more troubleshooting data, you can [view the kubelet logs][view-kubelet-logs] or [view the Kubernetes master node logs][view-master-logs]. +If you need more troubleshooting data, you can [view the kubelet logs][view-kubelet-logs] or [view the Kubernetes control plane logs][view-control-plane-logs]. -See [Manage SSH configuration][manage-ssh-node-access] to learn about managing the SSH key on an AKS cluster or node pools. +To learn about managing your SSH keys, see [Manage SSH configuration][manage-ssh-node-access]. <!-- INTERNAL LINKS --> [view-kubelet-logs]: kubelet-logs.md-[view-master-logs]: monitor-aks-reference.md#resource-logs +[view-control-plane-logs]: monitor-aks-reference.md#resource-logs [install-azure-cli]: /cli/azure/install-azure-cli [aks-windows-rdp]: rdp.md [azure-bastion]: ../bastion/bastion-overview.md [ssh-nix]: ../virtual-machines/linux/mac-create-ssh-keys.md [ssh-windows]: ../virtual-machines/linux/ssh-from-windows.md-[agentpool-rest-api]: /rest/api/aks/agent-pools/get#agentpool +[agent-pool-rest-api]: /rest/api/aks/agent-pools/get#agentpool [manage-ssh-node-access]: manage-ssh-node-access.md |
aks | Node Autoprovision | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/node-autoprovision.md | Title: Node autoprovisioning (Preview) description: Learn about Azure Kubernetes Service (AKS) Node autoprovisioning + Last updated 10/19/2023 #Customer intent: As a cluster operator or developer, how to scale my cluster based on workload requirements and right size my nodes automatically |
aks | Planned Maintenance | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/planned-maintenance.md | -AKS intiated maintenance refers to the AKS releases. These releases are weekly rounds of fixes and feature and component updates that affect your clusters. The type of maintenance that you initiate regularly are [cluster auto-upgrades][aks-upgrade] and [Node OS automatic security updates][node-image-auto-upgrade]. +AKS initiated maintenance refers to the AKS releases. These releases are weekly rounds of fixes and feature and component updates that affect your clusters. The type of maintenance that you initiate regularly are [cluster auto-upgrades][aks-upgrade] and [Node OS automatic security updates][node-image-auto-upgrade]. There are currently three available configuration types: `default`, `aksManagedAutoUpgradeSchedule`, `aksManagedNodeOSUpgradeSchedule`: |
aks | Supported Kubernetes Versions | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/supported-kubernetes-versions.md | Note the following important changes before you upgrade to any of the available | 1.25 | Azure policy 1.0.1<br>Metrics-Server 0.6.3<br>KEDA 2.9.3<br>Open Service Mesh 1.2.3<br>Core DNS V1.9.4<br>0.12.0</br>Overlay VPA 0.11.0<br>Azure-Keyvault-SecretsProvider 1.4.1<br>Application Gateway Ingress Controller (AGIC) 1.5.3<br>Image Cleaner v1.1.1<br>Azure Workload identity v1.0.0<br>MDC Defender 1.0.56<br>Azure Active Directory Pod Identity 1.8.13.6<br>GitOps 1.7.0<br>KMS 0.5.0| Cilium 1.12.8<br>CNI 1.4.44<br> Cluster Autoscaler 1.8.5.3<br> | OS Image Ubuntu 18.04 Cgroups V1 <br>ContainerD 1.7<br>Azure Linux 2.0<br>Cgroups V1<br>ContainerD 1.6<br>| Ubuntu 22.04 by default with cgroupv2 and Overlay VPA 0.13.0 |CgroupsV2 - If you deploy Java applications with the JDK, prefer to use JDK 11.0.16 and later or JDK 15 and later, which fully support cgroup v2 | 1.26 | Azure policy 1.0.1<br>Metrics-Server 0.6.3<br>KEDA 2.9.3<br>Open Service Mesh 1.2.3<br>Core DNS V1.9.4<br>0.12.0</br>Overlay VPA 0.11.0<br>Azure-Keyvault-SecretsProvider 1.4.1<br>Application Gateway Ingress Controller (AGIC) 1.5.3<br>Image Cleaner v1.1.1<br>Azure Workload identity v1.0.0<br>MDC Defender 1.0.56<br>Azure Active Directory Pod Identity 1.8.13.6<br>GitOps 1.7.0<br>KMS 0.5.0| Cilium 1.12.8<br>CNI 1.4.44<br> Cluster Autoscaler 1.8.5.3<br> | OS Image Ubuntu 22.04 Cgroups V2 <br>ContainerD 1.7<br>Azure Linux 2.0<br>Cgroups V1<br>ContainerD 1.6<br>|No breaking changes |None | 1.27 | Azure policy 1.1.0<br>Metrics-Server 0.6.3<br>KEDA 2.10.0<br>Open Service Mesh 1.2.3<br>Core DNS V1.9.4<br>0.12.0</br>Overlay VPA 0.11.0<br>Azure-Keyvault-SecretsProvider 1.4.1<br>Application Gateway Ingress Controller (AGIC) 1.7.2<br>Image Cleaner v1.1.1<br>Azure Workload identity v1.0.0<br>MDC Defender 1.0.56<br>Azure Active Directory Pod Identity 1.8.13.6<br>GitOps 1.7.0<br>KMS 0.5.0|Cilium 1.12.8<br>CNI 1.4.44<br> Cluster Autoscaler 1.8.5.3<br> | OS Image Ubuntu 22.04 Cgroups V2 <br>ContainerD 1.7 for Linux and 1.6 for Windows<br>Azure Linux 2.0<br>Cgroups V1<br>ContainerD 1.6<br>|Keda 2.10.0 |Because of Ubuntu 22.04 FIPS certification status, we'll switch AKS FIPS nodes from 18.04 to 20.04 from 1.27 onwards.-| 1.28 | Azure policy 1.2.1<br>Metrics-Server 0.6.3<br>KEDA 2.11.2<br>Open Service Mesh 1.2.7<br>Core DNS V1.9.4<br>0.12.0</br>Overlay VPA 0.13.0<br>Azure-Keyvault-SecretsProvider 1.4.1<br>Application Gateway Ingress Controller (AGIC) 1.7.2<br>Image Cleaner v1.2.2<br>Azure Workload identity v2.0.0<br>MDC Defender Security Publisher 1.0.68<br>MDC Defender Old File Cleaner 1.3.68<br>MDC Defender Pod Collector 1.0.78<br>MDC Defender Low Level Collector 1.3.81<br>Azure Active Directory Pod Identity 1.8.13.6<br>GitOps 1.8.1|Cilium 1.13.5<br>CNI v1.4.43.1 (Default)/v1.5.11 (Azure CNI Overlay)<br> Cluster Autoscaler 1.27.3<br> | OS Image Ubuntu 22.04 Cgroups V2 <br>ContainerD 1.7.5 for Linux and 1.7.1 for Windows<br>Azure Linux 2.0<br>Cgroups V1<br>ContainerD 1.6<br>|No breaking changes|None +| 1.28 | Azure policy 1.2.1<br>Metrics-Server 0.6.3<br>KEDA 2.11.2<br>Open Service Mesh 1.2.7<br>Core DNS V1.9.4<br>0.12.0</br>Overlay VPA 0.13.0<br>Azure-Keyvault-SecretsProvider 1.4.1<br>Application Gateway Ingress Controller (AGIC) 1.7.2<br>Image Cleaner v1.2.2<br>Azure Workload identity v1.2.0<br>MDC Defender Security Publisher 1.0.68<br>MDC Defender Old File Cleaner 1.3.68<br>MDC Defender Pod Collector 1.0.78<br>MDC Defender Low Level Collector 1.3.81<br>Azure Active Directory Pod Identity 1.8.13.6<br>GitOps 1.8.1|Cilium 1.13.5<br>CNI v1.4.43.1 (Default)/v1.5.11 (Azure CNI Overlay)<br> Cluster Autoscaler 1.27.3<br> | OS Image Ubuntu 22.04 Cgroups V2 <br>ContainerD 1.7.5 for Linux and 1.7.1 for Windows<br>Azure Linux 2.0<br>Cgroups V1<br>ContainerD 1.6<br>|No breaking changes|None ## Alias minor version |
aks | Use Kms Etcd Encryption | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/aks/use-kms-etcd-encryption.md | Title: Use Key Management Service (KMS) etcd encryption in Azure Kubernetes Serv description: Learn how to use the Key Management Service (KMS) etcd encryption with Azure Kubernetes Service (AKS) Previously updated : 08/04/2023 Last updated : 01/04/2024 # Add Key Management Service (KMS) etcd encryption to an Azure Kubernetes Service (AKS) cluster The above example stores the value of the identity resource ID in *IDENTITY_RESO ### Assign permissions (decrypt and encrypt) to access key vault +> [!NOTE] +> When using a private key vault, AKS can't validate the permissions of the identity. Verify the identity has been granted permission to access the key vault before enabling KMS. + #### For non-RBAC key vault If your key vault is not enabled with `--enable-rbac-authorization`, you can use `az keyvault set-policy` to create an Azure key vault policy. |
api-management | Import Api From Odata | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/api-management/import-api-from-odata.md | |
api-management | Quickstart Bicep | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/api-management/quickstart-bicep.md | |
api-management | Quickstart Terraform | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/api-management/quickstart-terraform.md | description: Use this quickstart to create an Azure API Management instance usin Last updated 12/12/2023-+ content_well_notification: In this article, you learn how to: ## Next steps > [!div class="nextstepaction"] -> [Tutorial: Import and publish your first API](import-and-publish.md) +> [Tutorial: Import and publish your first API](import-and-publish.md) |
app-service | App Service Best Practices | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/app-service/app-service-best-practices.md | Title: Best Practices -description: Learn best practices and the common troubleshooting scenarios for your app running in Azure App Service. + Title: Best practices for Azure App Service +description: Learn best practices and common troubleshooting scenarios for your app running in Azure App Service. ms.assetid: f3359464-fa44-4f4a-9ea6-7821060e8d0d -# Best Practices for Azure App Service -This article summarizes best practices for using [Azure App Service](./overview.md). +# Best practices for Azure App Service ++This article summarizes best practices for using [Azure App Service](./overview.md). ## <a name="colocation"></a>Colocation-When Azure resources composing a solution such as a web app and a database are located in different regions, it can have the following effects: ++An Azure App Service solution consists of a web app and a database or storage account for holding content or data. When these resources are in different regions, the situation can have the following effects: * Increased latency in communication between resources-* Monetary charges for outbound data transfer cross-region as noted on the [Azure pricing page](https://azure.microsoft.com/pricing/details/data-transfers). +* Monetary charges for outbound data transfer across regions, as noted on the [Azure pricing page](https://azure.microsoft.com/pricing/details/data-transfers) ++Colocation is best for Azure resources that compose a solution. When you create resources, make sure they're in the same Azure region unless you have specific business or design reasons for them not to be. You can move an App Service app to the same region as your database by using the [App Service cloning feature](app-service-web-app-cloning.md) available in Premium App Service plans. ++## <a name ="certificatepinning"></a>Certificate pinning ++Certificate pinning is a practice in which an application allows only a specific list of acceptable certificate authorities (CAs), public keys, thumbprints, or any part of the certificate hierarchy. ++Applications should never have a hard dependency or pin to the default wildcard (`*.azurewebsites.net`) TLS certificate. App Service is a platform as a service (PaaS), so this certificate could be rotated anytime. If the service rotates the default wildcard TLS certificate, certificate-pinned applications will break and disrupt the connectivity for applications that are hardcoded to a specific set of certificate attributes. The periodicity with which the certificate is rotated is also not guaranteed because the rotation frequency can change at any time. ++Applications that rely on certificate pinning also shouldn't have a hard dependency on an App Service managed certificate. App Service managed certificates could be rotated anytime, leading to similar problems for applications that rely on stable certificate properties. It's a best practice to provide a custom TLS certificate for applications that rely on certificate pinning. ++If your application needs to rely on certificate pinning behavior, we recommend that you add a custom domain to a web app and provide a custom TLS certificate for the domain. The application can then rely on the custom TLS certificate for certificate pinning. ++## <a name="memoryresources"></a>Memory resources ++When monitoring or service recommendations indicate that an app consumes more memory than you expected, consider the [App Service auto-healing feature](/azure/app-service/overview-diagnostics#auto-healing). You can configure auto-healing by using *web.config*. -Colocation in the same region is best for Azure resources composing a solution such as a web app and a database or storage account used to hold content or data. When creating resources, make sure they are in the same Azure region unless you have specific business or design reason for them not to be. You can move an App Service app to the same region as your database by using the [App Service cloning feature](app-service-web-app-cloning.md) currently available for Premium App Service Plan apps. +One of the options for the auto-healing feature is taking custom actions based on a memory threshold. Actions range from email notifications to investigation via memory dump to on-the-spot mitigation by recycling the worker process. -## <a name ="certificatepinning"></a>Certificate Pinning -Applications should never have a hard dependency or pin to the default \*.azurewebsites.net TLS certificate because the \*.azurewebsites.net TLS certificate could be rotated anytime given the nature of App Service as a Platform as a Service (PaaS). Certificate pinning is a practice where an application only allows a specific list of acceptable Certificate Authorities (CAs), public keys, thumbprints, or any part of the certificate hierarchy. In the event that the service rotates the App Service default wildcard TLS certificate, certificate pinned applications will break and disrupt the connectivity for applications that are hardcoded to a specific set of certificate attributes. The periodicity with which the \*.azurewebsites.net TLS certificate is rotated is also not guaranteed since the rotation frequency can change at any time. +## <a name="CPUresources"></a>CPU resources -Note that applications which rely on certificate pinning should also not have a hard dependency on an App Service Managed Certificate. App Service Managed Certificates could be rotated anytime, leading to similar problems for applications that rely on stable certificate properties. It is best practice to provide a custom TLS certificate for applications that rely on certificate pinning. +When monitoring or service recommendations indicate that an app consumes more CPU than you expected or it experiences repeated CPU spikes, consider scaling up or scaling out the App Service plan. If your application is stateful, scaling up is the only option. If your application is stateless, scaling out gives you more flexibility and higher scale potential. -If an application needs to rely on certificate pinning behavior, it is recommended to add a custom domain to a web app and provide a custom TLS certificate for the domain which can then be relied on for certificate pinning. +For more information about App Service scaling and autoscaling options, see [Scale up an app in Azure App Service](manage-scale-up.md). -## <a name="memoryresources"></a>When apps consume more memory than expected -When you notice an app consumes more memory than expected as indicated via monitoring or service recommendations, consider the [App Service Auto-Healing feature](https://azure.microsoft.com/blog/auto-healing-windows-azure-web-sites). One of the options for the Auto-Healing feature is taking custom actions based on a memory threshold. Actions span the spectrum from email notifications to investigation via memory dump to on-the-spot mitigation by recycling the worker process. Auto-healing can be configured via web.config and via a friendly user interface as described at in this blog post for the App Service Support Site Extension. +## <a name="socketresources"></a>Socket resources -## <a name="CPUresources"></a>When apps consume more CPU than expected -When you notice an app consumes more CPU than expected or experiences repeated CPU spikes as indicated via monitoring or service recommendations, consider scaling up or scaling out the App Service plan. If your application is stateful, scaling up is the only option, while if your application is stateless, scaling out gives you more flexibility and higher scale potential. +A common reason for exhausting outbound TCP connections is the use of client libraries that don't reuse TCP connections or that don't use a higher-level protocol such as HTTP keep-alive. -For more information about App Service scaling and autoscaling options, see [Scale a Web App in Azure App Service](manage-scale-up.md). +Review the documentation for each library that the apps in your App Service plan reference. Ensure that the libraries are configured or accessed in your code for efficient reuse of outbound connections. Also follow the library documentation guidance for proper creation and release or cleanup to avoid leaking connections. While such investigations into client libraries are in progress, you can mitigate impact by scaling out to multiple instances. -## <a name="socketresources"></a>When socket resources are exhausted -A common reason for exhausting outbound TCP connections is the use of client libraries, which are not implemented to reuse TCP connections, or when a higher-level protocol such as HTTP - Keep-Alive is not used. Review the documentation for each of the libraries referenced by the apps in your App Service Plan to ensure they are configured or accessed in your code for efficient reuse of outbound connections. Also follow the library documentation guidance for proper creation and release or cleanup to avoid leaking connections. While such client libraries investigations are in progress, impact may be mitigated by scaling out to multiple instances. +### Node.js and outgoing HTTP requests -### Node.js and outgoing http requests -When working with Node.js and many outgoing http requests, dealing with HTTP - Keep-Alive is important. You can use the [agentkeepalive](https://www.npmjs.com/package/agentkeepalive) `npm` package to make it easier in your code. +When you're working with Node.js and many outgoing HTTP requests, dealing with HTTP keep-alive is important. You can use the [agentkeepalive](https://www.npmjs.com/package/agentkeepalive) `npm` package to make it easier in your code. -Always handle the `http` response, even if you do nothing in the handler. If you don't handle the response properly, your application gets stuck eventually because no more sockets are available. +Always handle the `http` response, even if you do nothing in the handler. If you don't handle the response properly, your application eventually gets stuck because no more sockets are available. -For example, when working with the `http` or `https` package: +Here's an example of handling the response when you're working with the `http` or `https` package: ```javascript const request = https.request(options, function(response) { const request = https.request(options, function(response) { }); ``` -If you are running on App Service on Linux on a machine with multiple cores, another best practice is to use PM2 to start multiple Node.js processes to execute your application. You can do it by specifying a startup command to your container. +If you're running your App Service app on a Linux machine that has multiple cores, another best practice is to use PM2 to start multiple Node.js processes to run your application. You can do it by specifying a startup command to your container. -For example, to start four instances: +For example, use this command to start four instances: ``` pm2 start /home/site/wwwroot/app.js --no-daemon -i 4 ``` -## <a name="appbackup"></a>When your app backup starts failing -The two most common reasons why app backup fails are: invalid storage settings and invalid database configuration. These failures typically happen when there are changes to storage or database resources, or changes for how to access these resources (for example, credentials updated for the database selected in the backup settings). Backups typically run on a schedule and require access to storage (for outputting the backed-up files) and databases (for copying and reading contents to be included in the backup). The result of failing to access either of these resources would be consistent backup failure. +## <a name="appbackup"></a>App backup ++Backups typically run on a schedule and require access to storage (for outputting the backed-up files) and databases (for copying and reading contents to be included in the backup). The result of failing to access either of these resources is consistent backup failure. ++The two most common reasons why app backup fails are invalid storage settings and invalid database configuration. These failures typically happen after changes to storage or database resources, or after changes to credentials for accessing those resources. For example, credentials might be updated for the database that you selected in the backup settings. ++When backup failures happen, review the most recent results to understand which type of failure is happening. For storage access failures, review and update the storage settings in your backup configuration. For database access failures, review and update your connection strings as part of app settings. Then proceed to update your backup configuration to properly include the required databases. ++For more information on app backups, see [Back up and restore your app in Azure App Service](manage-backup.md). ++## <a name="nodejs"></a>Node.js apps ++The Azure App Service default configuration for Node.js apps is intended to best suit the needs of most common apps. If you want to personalize the default configuration for your Node.js app to improve performance or optimize resource usage for CPU, memory, or network resources, see [Best practices and troubleshooting guide for Node applications on Azure App Service](app-service-web-nodejs-best-practices-and-troubleshoot-guide.md). That article describes the iisnode settings that you might need to configure for your Node.js app. It also explains how to address scenarios or problems with your app. ++## <a name="iotdevices"></a>IoT devices ++You can improve your environment when you're running Internet of Things (IoT) devices that are connected to App Service. ++One common practice with IoT devices is certificate pinning. To avoid any unforeseen downtime due to changes in the service's managed certificates, you should never pin certificates to the default `*.azurewebsites.net` certificate or to an App Service managed certificate. If your system needs to rely on certificate pinning behavior, we recommend that you add a custom domain to a web app and provide a custom TLS certificate for the domain. The application can then rely on the custom TLS certificate for certificate pinning. For more information, see the [certificate pinning](#certificatepinning) section of this article. -When backup failures happen, review most recent results to understand which type of failure is happening. For storage access failures, review and update the storage settings used in the backup configuration. For database access failures, review and update your connections strings as part of app settings; then proceed to update your backup configuration to properly include the required databases. For more information on app backups, see [Back up a web app in Azure App Service](manage-backup.md). +To increase resiliency in your environment, don't rely on a single endpoint for all your devices. Host your web apps in at least two regions to avoid a single point of failure, and be ready to fail over traffic. -## <a name="nodejs"></a>When new Node.js apps are deployed to Azure App Service -Azure App Service default configuration for Node.js apps is intended to best suit the needs of most common apps. If configuration for your Node.js app would benefit from personalized tuning to improve performance or optimize resource usage for CPU/memory/network resources, see [Best practices and troubleshooting guide for Node applications on Azure App Service](app-service-web-nodejs-best-practices-and-troubleshoot-guide.md). This article describes the iisnode settings you may need to configure for your Node.js app, describes the various scenarios or issues that your app may be facing, and shows how to address these issues. +In App Service, you can add identical custom domains to multiple web apps, as long as these web apps are hosted in different regions. This capability ensures that if you need to pin certificates, you can also pin on the custom TLS certificate that you provided. -## <a name=""></a>When Internet of Things (IoT) devices are connected to apps on App Service -There are a few scenarios where you can improve your environment when running Internet of Things (IoT) devices that are connected to App Service. One very common practice with IoT devices is "certificate pinning". To avoid any unforeseen downtime due to changes in the service's managed certificates, you should never pin certificates to the default \*.azurewebsites.net certificate nor to an App Service Managed Certificate. If your system needs to rely on certificate pinning behavior, it is recommended to add a custom domain to a web app and provide a custom TLS certificate for the domain which can then be relied on for certificate pinning. You can refer to the [certificate pinning](#certificatepinning) section of this article for more information. +Another option is to use a load balancer in front of the web apps, such as Azure Front Door or Azure Traffic Manager, to ensure high availability for your web apps. For more information, see [Quickstart: Create a Front Door instance for a highly available global web application](../frontdoor/quickstart-create-front-door.md) or [Controlling Azure App Service traffic with Azure Traffic Manager](./web-sites-traffic-manager.md). -To increase resiliency in your environment, you should not rely on a single endpoint for all your devices. You should at least host your web apps in two different regions to avoid a single point of failure and be ready to failover traffic. On App Service, you can add identical custom domain to different web apps as long as these web apps are hosted in different regions. This ensures that if you need to pin certificates, you can also pin on the custom TLS certificate that you provided. Another option would be to use a load balancer in front of the web apps, such as Azure Front Door or Traffic Manager, to ensure high availability for your web apps. You can refer to [Quickstart: Create a Front Door for a highly available global web application](../frontdoor/quickstart-create-front-door.md) or [Controlling Azure App Service traffic with Azure Traffic Manager](./web-sites-traffic-manager.md) for more information. +## Next steps -## Next Steps -For more information on best practices, visit [App Service Diagnostics](./overview-diagnostics.md) to find out actionable best practices specific to your resource. +To get actionable best practices that are specific to your resource, use [App Service diagnostics](./overview-diagnostics.md): -- Navigate to your Web App in the [Azure portal](https://portal.azure.com).-- Click on **Diagnose and solve problems** in the left navigation, which opens App Service Diagnostics.-- Choose **Best Practices** homepage tile.-- Click **Best Practices for Availability & Performance** or **Best Practices for Optimal Configuration** to view the current state of your app in regards to these best practices.+1. Go to your web app in the [Azure portal](https://portal.azure.com). +1. Open App Service diagnostics by selecting **Diagnose and solve problems** on the left pane. +1. Select the **Best Practices** tile. +1. Select **Best Practices for Availability & Performance** or **Best Practices for Optimal Configuration** to view the current state of your app in regard to these best practices. -You can also use this link to directly open App Service Diagnostics for your resource: `https://portal.azure.com/?websitesextension_ext=asd.featurePath%3Ddetectors%2FParentAvailabilityAndPerformance#@microsoft.onmicrosoft.com/resource/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/troubleshoot`. +You can also use this link to directly open App Service diagnostics for your resource: `https://portal.azure.com/?websitesextension_ext=asd.featurePath%3Ddetectors%2FParentAvailabilityAndPerformance#@microsoft.onmicrosoft.com/resource/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/troubleshoot`. |
app-service | Configure Ssl Bindings | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/app-service/configure-ssl-bindings.md | tags: buy-ssl-certificates Last updated 04/20/2023 -+ |
app-service | Language Support Policy | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/app-service/language-support-policy.md | If a supported Java runtime will be retired, Azure developers using the affected Developers can download the Microsoft Build of OpenJDK for local development from [our download site](/java/openjdk/download). Product support for the [Microsoft Build of OpenJDK](/java/openjdk/download) is available through Microsoft when developing for Azure or [Azure Stack](https://azure.microsoft.com/overview/azure-stack/) with a [qualified Azure support plan](https://azure.microsoft.com/support/plans/).- |
app-service | Operating System Functionality | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/app-service/operating-system-functionality.md | Title: Operating system functionality -description: Learn about the OS functionality in Azure App Service on Windows. Find out what types of file, network, and registry access your app gets. + Title: Operating system functionality in Azure App Service +description: Learn what types of file, network, and registry access your Windows app gets when it runs in Azure App Service. ms.assetid: 39d5514f-0139-453a-b52e-4a1c06d8d914 Last updated 01/21/2022 -# Operating system functionality on Azure App Service -This article describes the common baseline operating system functionality that is available to all Windows apps running on [Azure App Service](./overview.md). This functionality includes file, network, and registry access, and diagnostics logs and events. +# Operating system functionality in Azure App Service -> [!NOTE] -> [Linux apps](overview.md#app-service-on-linux) in App Service run in their own containers. You have root access to the container but no access to the host operating system is allowed. Likewise, for [apps running in Windows containers](quickstart-custom-container.md?pivots=container-windows), you have administrative access to the container but no access to the host operating system. -> +This article describes the baseline operating system functionality that's available to all Windows apps running in [Azure App Service](./overview.md). This functionality includes file, network, and registry access, along with diagnostics logs and events. ++> [!NOTE] +> [Linux apps](overview.md#app-service-on-linux) in App Service run in their own containers. You have root access to the container but no access to the host operating system. Likewise, for [apps running in Windows containers](quickstart-custom-container.md?pivots=container-windows), you have administrative access to the container but no access to the host operating system. <a id="tiers"></a> ## App Service plan tiers-App Service runs customer apps in a multi-tenant hosting environment. Apps deployed in the **Free** and **Shared** tiers run in worker processes on shared virtual machines, while apps deployed in the **Standard** and **Premium** tiers run on virtual machine(s) dedicated specifically for the apps associated with a single customer. ++App Service runs customer apps in a multitenant hosting environment. Apps deployed in the Free and Shared tiers run in worker processes on shared virtual machines (VMs). Apps deployed in the Standard and Premium tiers run on VMs dedicated specifically for the apps associated with a single customer. [!INCLUDE [app-service-dev-test-note](../../includes/app-service-dev-test-note.md)] -Because App Service supports a seamless scaling experience between different tiers, the security configuration enforced for App Service apps remains the same. This ensures that apps don't suddenly behave differently, failing in unexpected ways, when an App Service plan switches from one tier to another. +Because App Service supports a seamless scaling experience between tiers, the security configuration enforced for App Service apps remains the same. This configuration ensures that apps don't suddenly behave differently and fail in unexpected ways when an App Service plan switches from one tier to another. <a id="developmentframeworks"></a> ## Development frameworks+ App Service pricing tiers control the amount of compute resources (CPU, disk storage, memory, and network egress) available to apps. However, the breadth of framework functionality available to apps remains the same regardless of the scaling tiers. -App Service supports a variety of development frameworks, including ASP.NET, classic ASP, Node.js, PHP, and Python. -In order to simplify and normalize security configuration, App Service apps typically run the various development frameworks with their default settings. The frameworks and runtime components provided by the platform are updated regularly to satisfy security and compliance requirements, for this reason we don't guarantee specific minor/patch versions and recommend customers target major version as needed. +App Service supports various development frameworks, including ASP.NET, classic ASP, Node.js, PHP, and Python. To simplify and normalize security configuration, App Service apps typically run the development frameworks with their default settings. The frameworks and runtime components that the platform provides are updated regularly to satisfy security and compliance requirements. For this reason, we don't guarantee specific minor/patch versions. We recommend that customers target major versions as needed. The following sections summarize the general kinds of operating system functionality available to App Service apps. <a id="FileAccess"></a> ## File access+ Various drives exist within App Service, including local drives and network drives. <a id="LocalDrives"></a> ### Local drives-At its core, App Service is a service running on top of the Azure PaaS (platform as a service) infrastructure. As a result, the local drives that are "attached" to a virtual machine are the same drive types available to any worker role running in Azure. This includes: -- An operating system drive (`%SystemDrive%`), whose size varies depending on the size of the VM.-- A resource drive (`%ResourceDrive%`) used by App Service internally.+At its core, App Service is a service running on top of the Azure platform as a service (PaaS) infrastructure. As a result, the local drives that are associated with a virtual machine are the same drive types available to any worker role running in Azure. They include: -A best practice is to always use the environment variables `%SystemDrive%` and `%ResourceDrive%` instead of hard-coded file paths. The root path returned from these two environment variables has shifted over time from `d:\` to `c:\`. However, older applications hard-coded with file path references to `d:\` will continue to work because the App Service platform automatically remaps `d:\` to instead point at `c:\`. As noted above, it's highly recommended to always use the environment variables when building file paths and avoid confusion over platform changes to the default root file path. +- An operating system drive (`%SystemDrive%`) whose size depends on the size of the VM. +- A resource drive (`%ResourceDrive%`) that App Service uses internally. -It's important to monitor your disk utilization as your application grows. If the disk quota is reached, it can have adverse effects to your application. For example: +A best practice is to always use the environment variables `%SystemDrive%` and `%ResourceDrive%` instead of hard-coded file paths. The root path returned from these two environment variables has shifted over time from `d:\` to `c:\`. However, older applications hard-coded with file path references to `d:\` continue to work because App Service automatically remaps `d:\` to point at `c:\`. As noted earlier, we highly recommend that you always use the environment variables when building file paths and avoid confusion over platform changes to the default root file path. -- The app may throw an error indicating not enough space on the disk.-- You may see disk errors when browsing to the Kudu console.-- Deployment from Azure DevOps or Visual Studio may fail with `ERROR_NOT_ENOUGH_DISK_SPACE: Web deployment task failed. (Web Deploy detected insufficient space on disk)`.-- Your app may suffer slow performance.+It's important to monitor your disk utilization as your application grows. Reaching the disk quota can have adverse effects on your application. For example: ++- The app might throw an error that indicates there's not enough space on the disk. +- You might see disk errors when browsing to the Kudu console. +- Deployment from Azure DevOps or Visual Studio might fail with `ERROR_NOT_ENOUGH_DISK_SPACE: Web deployment task failed. (Web Deploy detected insufficient space on disk)`. +- Your app might have slow performance. <a id="NetworkDrives"></a> ### Network drives (UNC shares)-One of the unique aspects of App Service that makes app deployment and maintenance straightforward is that all content shares are stored on a set of UNC shares. This model maps well to the common pattern of content storage used by on-premises web hosting environments that have multiple load-balanced servers. -Within App Service, there is a number of UNC shares created in each data center. A percentage of the user content for all customers in each data center is allocated to each UNC share. Each customer's subscription has a reserved directory structure on a specific UNC share within a data center. A customer may have multiple apps created within a specific data center, so all of the directories belonging to a single customer subscription are created on the same UNC share. +One of the unique aspects of App Service that make app deployment and maintenance straightforward is that all content shares are stored on a set of UNC shares. This model maps well to the common pattern of content storage used by on-premises web hosting environments that have multiple load-balanced servers. ++Within App Service, UNC shares are created in each datacenter. A percentage of the user content for all customers in each datacenter is allocated to each UNC share. Each customer's subscription has a reserved directory structure on a specific UNC share in a datacenter. A customer might have multiple apps created in a specific datacenter, so all of the directories that belong to a single customer subscription are created on the same UNC share. -Due to how Azure services work, the specific virtual machine responsible for hosting a UNC share will change over time. It is guaranteed that UNC shares will be mounted by different virtual machines as they're brought up and down during the normal course of Azure operations. For this reason, apps should never make hard-coded assumptions that the machine information in a UNC file path will remain stable over time. Instead, they should use the convenient *faux* absolute path `%HOME%\site` that App Service provides. This faux absolute path provides a portable, app-and-user-agnostic method for referring to one's own app. By using `%HOME%\site`, one can transfer shared files from app to app without having to configure a new absolute path for each transfer. +Because of the way that Azure services work, the specific virtual machine responsible for hosting a UNC share changes over time. UNC shares are mounted by different virtual machines as they're brought up and down during the normal course of Azure operations. For this reason, apps should never make hard-coded assumptions that the machine information in a UNC file path will remain stable over time. Instead, they should use the convenient *faux* absolute path `%HOME%\site` that App Service provides. ++The faux absolute path is a portable method for referring to your own app. It's not specific to any app or user. By using `%HOME%\site`, you can transfer shared files from app to app without having to configure a new absolute path for each transfer. <a id="TypesOfFileAccess"></a> ### Types of file access granted to an app-The `%HOME%` directory in an app maps to a content share in Azure Storage dedicated for that app, and its size is defined by your [pricing tier](https://azure.microsoft.com/pricing/details/app-service/). It may include directories such as those for content, error and diagnostic logs, and earlier versions of the app created by source control. These directories are available to the app's application code at runtime for read and write access. Because the files aren't stored locally, they're persistent across app restarts. -On the system drive, App Service reserves `%SystemDrive%\local` for app-specific temporary local storage. Changes to files in this directory are *not* persistent across app restarts. Although an app has full read/write access to its own temporary local storage, that storage really isn't intended to be used directly by the application code. Rather, the intent is to provide temporary file storage for IIS and web application frameworks. App Service also limits the amount of storage in `%SystemDrive%\local` for each app to prevent individual apps from consuming excessive amounts of local file storage. For **Free**, **Shared**, and **Consumption** (Azure Functions) tiers, the limit is 500 MB. See the following table for other tiers: +The `%HOME%` directory in an app maps to a content share in Azure Storage dedicated for that app. Your [pricing tier](https://azure.microsoft.com/pricing/details/app-service/) defines its size. It might include directories such as those for content, error and diagnostic logs, and earlier versions of the app that source control created. These directories are available to the app's application code at runtime for read and write access. Because the files aren't stored locally, they're persistent across app restarts. ++On the system drive, App Service reserves `%SystemDrive%\local` for app-specific temporary local storage. Changes to files in this directory are *not* persistent across app restarts. Although an app has full read and write access to its own temporary local storage, that storage isn't intended for direct use by the application code. Rather, the intent is to provide temporary file storage for IIS and web application frameworks. -| SKU | Local file storage | +App Service limits the amount of storage in `%SystemDrive%\local` for each app to prevent individual apps from consuming excessive amounts of local file storage. For Free, Shared, and Consumption (Azure Functions) tiers, the limit is 500 MB. The following table lists other tiers: ++| Tier | Local file storage | | - | - |-| B1/S1/P1 | 11GB | -| B2/S2/P2 | 15GB | -| B3/S3/P3 | 58GB | -| P0v3 | 11GB | -| P1v2/P1v3/P1mv3/Isolated1/Isolated1v2 | 21GB | -| P2v2/P2v3/P2mv3/Isolated2/Isolated2v2 | 61GB | -| P3v2/P3v3/P3mv3/Isolated3/Isolated3v2 | 140GB | -| Isolated4v2 | 276GB| -| P4mv3 | 280GB | -| Isolated5v2 | 552GB| -| P5mv3 | 560GB | -| Isolated6v2 | 1104GB| --Two examples of how App Service uses temporary local storage are the directory for temporary ASP.NET files and the directory for IIS compressed files. The ASP.NET compilation system uses the `%SystemDrive%\local\Temporary ASP.NET Files` directory as a temporary compilation cache location. IIS uses the `%SystemDrive%\local\IIS Temporary Compressed Files` directory to store compressed response output. Both of these types of file usage (as well as others) are remapped in App Service to per-app temporary local storage. This remapping ensures that functionality continues as expected. --Each app in App Service runs as a random unique low-privileged worker process identity called the "application pool identity", described further in the IIS [Application Pool Identities](/iis/manage/configuring-security/application-pool-identities) documentation. Application code uses this identity for basic read-only access to the operating system drive. This means application code can list common directory structures and read common files on operating system drive. Although this might appear to be a somewhat broad level of access, the same directories and files are accessible when you provision a worker role in an Azure hosted service and read the drive contents. +| B1/S1/P1 | 11 GB | +| B2/S2/P2 | 15 GB | +| B3/S3/P3 | 58 GB | +| P0v3 | 11 GB | +| P1v2/P1v3/P1mv3/Isolated1/Isolated1v2 | 21 GB | +| P2v2/P2v3/P2mv3/Isolated2/Isolated2v2 | 61 GB | +| P3v2/P3v3/P3mv3/Isolated3/Isolated3v2 | 140 GB | +| Isolated4v2 | 276 GB| +| P4mv3 | 280 GB | +| Isolated5v2 | 552 GB| +| P5mv3 | 560 GB | +| Isolated6v2 | 1,104 GB| ++Two examples of how App Service uses temporary local storage are the directory for temporary ASP.NET files and the directory for IIS compressed files. The ASP.NET compilation system uses the `%SystemDrive%\local\Temporary ASP.NET Files` directory as a temporary compilation cache location. IIS uses the `%SystemDrive%\local\IIS Temporary Compressed Files` directory to store compressed response output. Both of these types of file usage (along with others) are remapped in App Service to per-app temporary local storage. This remapping helps ensure that functionality continues as expected. ++Each app in App Service runs as a random, unique, low-privileged worker process identity called the [application pool identity](/iis/manage/configuring-security/application-pool-identities). Application code uses this identity for basic read-only access to the operating system drive. This access means that application code can list common directory structures and read common files on the operating system drive. Although this level of access might seem to be broad, the same directories and files are accessible when you provision a worker role in an Azure-hosted service and read the drive contents. <a name="multipleinstances"></a> ### File access across multiple instances-The content share (`%HOME%`) directory contains an app's content, and application code can write to it. If an app runs on multiple instances, the `%HOME%` directory is shared among all instances so that all instances see the same directory. So, for example, if an app saves uploaded files to the `%HOME%` directory, those files are immediately available to all instances. -The temporary local storage (`%SystemDrive%\local`) directory is not shared between instances, neither is it shared between the app and its [Kudu app](resources-kudu.md). +The content share (`%HOME%`) directory contains an app's content, and application code can write to it. If an app runs on multiple instances, the `%HOME%` directory is shared among all instances so that all instances see the same directory. For example, if an app saves uploaded files to the `%HOME%` directory, those files are immediately available to all instances. ++The temporary local storage (`%SystemDrive%\local`) directory is not shared between instances. It's also not shared between the app and its [Kudu app](resources-kudu.md). <a id="NetworkAccess"></a> ## Network access-Application code can use TCP/IP and UDP-based protocols to make outbound network connections to Internet accessible endpoints that expose external services. Apps can use these same protocols to connect to services within Azure, for example, by establishing HTTPS connections to SQL Database. -There's also a limited capability for apps to establish one local loopback connection, and have an app listen on that local loopback socket. This feature exists primarily to enable apps that listen on local loopback sockets as part of their functionality. Each app sees a "private" loopback connection. App "A" cannot listen to a local loopback socket established by app "B". +Application code can use TCP/IP and UDP-based protocols to make outbound network connections to internet-accessible endpoints that expose external services. Apps can use these same protocols to connect to services within Azure--for example, by establishing HTTPS connections to Azure SQL Database. -Named pipes are also supported as an inter-process communication (IPC) mechanism between different processes that collectively run an app. For example, the IIS FastCGI module relies on named pipes to coordinate the individual processes that run PHP pages. +There's also a limited capability for apps to establish one local loopback connection and have an app listen on that local loopback socket. This feature enables apps that listen on local loopback sockets as part of their functionality. Each app has a private loopback connection. One app can't listen to a local loopback socket that another app established. ++Named pipes are also supported as a mechanism for interprocess communication between processes that collectively run an app. For example, the IIS FastCGI module relies on named pipes to coordinate the individual processes that run PHP pages. <a id="Code"></a> ## Code execution, processes, and memory-As noted earlier, apps run inside of low-privileged worker processes using a random application pool identity. Application code has access to the memory space associated with the worker process, as well as any child processes that may be spawned by CGI processes or other applications. However, one app cannot access the memory or data of another app even if it's on the same virtual machine. -Apps can run scripts or pages written with supported web development frameworks. App Service doesn't configure any web framework settings to more restricted modes. For example, ASP.NET apps running on App Service run in "full" trust as opposed to a more restricted trust mode. Web frameworks, including both classic ASP and ASP.NET, can call in-process COM components (but not out of process COM components) like ADO (ActiveX Data Objects) that are registered by default on the Windows operating system. +As noted earlier, apps run inside low-privileged worker processes by using a random application pool identity. Application code has access to the memory space associated with the worker process, along with any child processes that CGI processes or other applications might spawn. However, one app can't access the memory or data of another app, even if it's on the same virtual machine. ++Apps can run scripts or pages written with supported web development frameworks. App Service doesn't configure any web framework settings to more restricted modes. For example, ASP.NET apps running in App Service run in full trust, as opposed to a more restricted trust mode. Web frameworks, including both classic ASP and ASP.NET, can call in-process COM components (like ActiveX Data Objects) that are registered by default on the Windows operating system. Web frameworks can't call out-of-process COM components. -Apps can spawn and run arbitrary code. It's allowable for an app to do things like spawn a command shell or run a PowerShell script. However, even though arbitrary code and processes can be spawned from an app, executable programs and scripts are still restricted to the privileges granted to the parent application pool. For example, an app can spawn an executable that makes an outbound HTTP call, but that same executable cannot attempt to unbind the IP address of a virtual machine from its NIC. Making an outbound network call is allowed to low-privileged code, but attempting to reconfigure network settings on a virtual machine requires administrative privileges. +An app can spawn and run arbitrary code, open a command shell, or run a PowerShell script. However, executable programs and scripts are still restricted to the privileges granted to the parent application pool. For example, an app can spawn an executable program that makes an outbound HTTP call, but that executable program can't try to unbind the IP address of a virtual machine from its network adapter. Making an outbound network call is allowed for low-privileged code, but trying to reconfigure network settings on a virtual machine requires administrative privileges. <a id="Diagnostics"></a> ## Diagnostics logs and events-Log information is another set of data that some apps attempt to access. The types of log information available to code running in App Service includes diagnostic and log information generated by an app that is also easily accessible to the app. -For example, W3C HTTP logs generated by an active app are available either on a log directory in the network share location created for the app, or available in blob storage if a customer has set up W3C logging to storage. The latter option enables large quantities of logs to be gathered without the risk of exceeding the file storage limits associated with a network share. +Log information is another set of data that some apps try to access. The types of log information available to code running in App Service include diagnostic and log information that an app generates and can easily access. -In a similar vein, real-time diagnostics information from .NET apps can also be logged using the .NET tracing and diagnostics infrastructure, with options to write the trace information to either the app's network share, or alternatively to a blob storage location. +For example, app-generated W3C HTTP logs are available either: -Areas of diagnostics logging and tracing that aren't available to apps are Windows ETW events and common Windows event logs (for example, System, Application, and Security event logs). Since ETW trace information can potentially be viewable machine-wide (with the right ACLs), read and write access to ETW events are blocked. Developers might notice that API calls to read and write ETW events and common Windows event logs appear to work, but that is because App Service is "faking" the calls so that they appear to succeed. In reality, the application code has no access to this event data. +- In a log directory in the network share location that you created for the app +- In blob storage if you set up W3C logging to storage ++The latter option enables apps to gather large amounts of logs without exceeding the file storage limits associated with a network share. ++Similarly, real-time diagnostics information from .NET apps can be logged through the .NET tracing and diagnostics infrastructure. You can then write the trace information to either the app's network share or a blob storage location. ++Areas of diagnostics logging and tracing that aren't available to apps are Windows Event Tracing for Windows (ETW) events and common Windows event logs (for example, system, application, and security event logs). Because ETW trace information can potentially be viewable across a machine (with the right access control lists), read access and write access to ETW events are blocked. API calls to read and write ETW events and common Windows event logs might seem to work, but in reality, the application code has no access to this event data. <a id="RegistryAccess"></a> ## Registry access-Apps have read-only access to much (though not all) of the registry of the virtual machine they're running on. In practice, this means registry keys that allow read-only access to the local Users group are accessible by apps. One area of the registry that is currently not supported for either read or write access is the HKEY\_CURRENT\_USER hive. -Write-access to the registry is blocked, including access to any per-user registry keys. From the app's perspective, write access to the registry should never be relied upon in the Azure environment since apps can (and do) get migrated across different virtual machines. The only persistent writeable storage that can be depended on by an app is the per-app content directory structure stored on the App Service UNC shares. +Apps have read-only access to much (though not all) of the registry of the virtual machine that they're running on. This access means that apps can access registry keys that allow read-only access to the Local Users group. One area of the registry that's currently not supported for either read or write access is the `HKEY\_CURRENT\_USER` hive. ++Write access to the registry is blocked, including access to any per-user registry keys. From the app's perspective, it can't rely on write access to the registry in the Azure environment because apps can be migrated across virtual machines. The only persistent writeable storage that an app can depend on is the per-app content directory structure stored on the App Service UNC shares. ## Remote desktop access App Service doesn't provide remote desktop access to the VM instances. ## More information -[Azure App Service sandbox](https://github.com/projectkudu/kudu/wiki/Azure-Web-App-sandbox) - The most up-to-date information about the execution environment of App Service. This page is -maintained directly by the App Service development team. +For the most up-to-date information about the execution environment of App Service, see the [Azure App Service sandbox](https://github.com/projectkudu/kudu/wiki/Azure-Web-App-sandbox). The App Service development team maintains this page. |
app-service | Resources Kudu | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/app-service/resources-kudu.md | -Kudu is the engine behind a number of features in [Azure App Service](overview.md) related to source control based deployment, and other deployment methods like Dropbox and OneDrive sync. +Kudu is the engine behind some features in [Azure App Service](overview.md) that are related to source-control-based deployment and other deployment methods, like Dropbox and OneDrive sync. ## Access Kudu for your app-Anytime you create an app, App Service creates a companion app for it that's secured by HTTPS. This Kudu app is accessible at: -- App not in Isolated tier: `https://<app-name>.scm.azurewebsites.net`-- Internet-facing app in Isolated tier (App Service Environment): `https://<app-name>.scm.<ase-name>.p.azurewebsites.net`-- Internal app in Isolated tier (ILB App Service Environment): `https://<app-name>.scm.<ase-name>.appserviceenvironment.net`+Anytime you create an app, App Service creates a companion app for it that's secured by HTTPS. This Kudu app is accessible at these URLs: ++- App not in the Isolated tier: `https://<app-name>.scm.azurewebsites.net` +- Internet-facing app in the Isolated tier (App Service Environment): `https://<app-name>.scm.<ase-name>.p.azurewebsites.net` +- Internal app in the Isolated tier (App Service Environment for internal load balancing): `https://<app-name>.scm.<ase-name>.appserviceenvironment.net` -For more information, see [Accessing the kudu service](https://github.com/projectkudu/kudu/wiki/Accessing-the-kudu-service). +For more information, see [Accessing the Kudu service](https://github.com/projectkudu/kudu/wiki/Accessing-the-kudu-service). ## Kudu features Kudu gives you helpful information about your App Service app, such as: - Server variables - HTTP headers -It also provides other features, such as: +It also provides features like these: - Run commands in the [Kudu console](https://github.com/projectkudu/kudu/wiki/Kudu-console). - Download IIS diagnostic dumps or Docker logs. - Manage IIS processes and site extensions. - Add deployment webhooks for Windows apps. - Allow ZIP deployment UI with `/ZipDeploy`.-- Generates [custom deployment scripts](https://github.com/projectkudu/kudu/wiki/Custom-Deployment-Script).-- Allows access with [REST API](https://github.com/projectkudu/kudu/wiki/REST-API).+- Generate [custom deployment scripts](https://github.com/projectkudu/kudu/wiki/Custom-Deployment-Script). +- Allow access with a [REST API](https://github.com/projectkudu/kudu/wiki/REST-API). ## RBAC permissions required to access Kudu-To access Kudu in the browser with Microsoft Entra authentication, you need to be a member of a built-in or custom role. -- If using a built-in role, you must be a member of Website Contributor, Contributor, or Owner.-- If using a custom role, you need the resource provider operation: `Microsoft.Web/sites/publish/Action`.+To access Kudu in the browser by using Microsoft Entra authentication, you need to be a member of a built-in or custom role. ++If you're using a built-in role, you must be a member of Website Contributor, Contributor, or Owner. If you're using a custom role, you need the resource provider operation: `Microsoft.Web/sites/publish/Action`. -## More Resources +## More resources -Kudu is an [open source project](https://github.com/projectkudu/kudu), and has its documentation at [Kudu Wiki](https://github.com/projectkudu/kudu/wiki). +Kudu is an [open-source project](https://github.com/projectkudu/kudu). It has documentation on the [Kudu wiki](https://github.com/projectkudu/kudu/wiki). |
app-service | Routine Maintenance | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/app-service/routine-maintenance.md | Title: App Service routine maintenance -description: Learn more about the routine, planned maintenance to keep the App Service platform up-to-date and secure. + Title: Routine maintenance for Azure App Service +description: Learn more about routine, planned maintenance to help keep the App Service platform up to date and secure. tags: app-service -# Routine (planned) maintenance for App Service -Routine maintenance covers behind the scenes updates to the Azure App Service platform. Types of maintenance can be performance improvements, bug fixes, -new features, or security updates. App Service maintenance can be on App Service itself or the underlying operating system. +# Routine (planned) maintenance for Azure App Service ->[!IMPORTANT] ->A breaking change or deprecation of functionality is not a part of routine maintenance (see [Modern Lifecycle Policy - Microsoft Lifecycle | Microsoft Learn](/lifecycle/policies/modern) for deprecation topic for details). -> +Routine maintenance covers behind-the-scenes updates to Azure App Service. Types of maintenance can be performance improvements, bug fixes, new features, or security updates. App Service maintenance can be on the service itself or the underlying operating system. -Our service quality and uptime guarantees continue to apply during maintenance periods. Maintenance periods are mentioned to help customers to get visibility into platform changes. +> [!IMPORTANT] +> A breaking change or deprecation of functionality is not a part of routine maintenance. For more information, see [Modern Lifecycle Policy](/lifecycle/policies/modern). ++Microsoft service quality and uptime guarantees continue to apply during maintenance periods. Notifications mention maintenance periods to help customers get visibility into platform changes. ## What to expect -Like security updates on personal computers, mobile phones and other devices, even machines in the cloud need the latest updates. Unlike physical devices, cloud solutions like Azure App Service provide ways to overcome these routines with more ease. There's no need to "stop working" for a certain period and wait until patches are installed. Any workload can be shifted to different hardware in a matter of seconds and while updates are installed. The updates are made monthly, but can vary on the needs and other factors. +Like personal computers, mobile phones, and other devices, machines in the cloud need the latest updates. Unlike physical devices, cloud solutions like Azure App Service provide ways to handle routine maintenance with more ease. There's no need to stop working and wait until patches are installed. Any workload can be shifted to different hardware in a matter of seconds and while updates are installed. The updates happen monthly but can vary, depending on your organization's needs and other factors. ++Because a typical cloud solution consists of multiple applications, databases, storage accounts, functions, and other resources, parts of your solutions can undergo maintenance at different times. Some of this coordination is related to geography, region, datacenters, and availability zones. It can also be due to the cloud, where not everything is touched simultaneously. For more information, see [Safe deployment practices](/devops/operate/safe-deployment-practices). -Since a typical cloud solution consists of multiple applications, databases, storage accounts, functions, and other resources, various parts of your solutions can be undergoing maintenance at different times. Some of this coordination is related to geography, region, data centers, and availability zones. It can also be due to the cloud where not everything is touched simultaneously. +The following screenshot shows an example of a maintenance event. -[Safe deployment practices - Azure DevOps | Microsoft Learn](/devops/operate/safe-deployment-practices) +In order from top to bottom, the example shows: -In order from top to bottom we see: -- A descriptive title of the maintenance event-- Impacted regions and subscriptions-- Expected maintenance window+- A descriptive title of the maintenance event. +- Affected regions and subscriptions. +- The expected maintenance window. -## Frequently Asked Questions +## Frequently asked questions ### Why is the maintenance taking so long? -The maintenance fundamentally represents delivering latest updates to the platform and service. It's difficult to predict when individual apps would be affected down to a specific time, so more generic notifications are sent out. The time ranges in those notifications don't reflect the experiences at the app level, but the overall operation across all resources. Apps which undergo maintenance instantly restart on freshly updated machines and continue working. There's no downtime when requests/traffic aren't served. +Fundamentally, routine maintenance delivers the latest updates to the platform and service. It's hard to predict how the maintenance will affect individual apps down to a specific time, so notifications tend to be more general. The time ranges in notifications don't reflect the experiences at the app level, but rather the overall operation across all resources. Apps that undergo maintenance instantly restart on freshly updated machines and continue working. There's no downtime when requests and traffic aren't served. ### Why am I getting so many notifications? -A typical scenario is that customers have multiple applications, and they are upgraded at different times. To avoid sending notifications for each of them, a more generic notification is sent that captures multiple resources. The notification is sent at the beginning and throughout the maintenance window. Due to the time window being longer, you can receive multiple reminders for the same rollout so you can easier correlate any restart/interruption/issue in case it is needed. +A typical scenario is that customers have multiple applications that are upgraded at different times. To avoid sending notifications for each of them, we send one notification that captures multiple resources. We send the notification at the beginning and throughout the maintenance window. You might receive multiple reminders for the same rollout if the time window is long, so you can more easily correlate any restarts, interruptions, or other issues. ### How is routine maintenance related to SLA? -Platform maintenance isn't expected to impact application uptime or availability. Applications continue to stay online while platform maintenance occurs. Platform maintenance may cause applications to be cold started on new virtual machines, which can lead to cold start delays. An application is still considered to be online, even while cold-starting. For best practices to minimize/avoid cold starts, consider using [local cache for Windows apps](overview-local-cache.md) as well as [Health check](monitor-instances-health-check.md). It's not expected that sites would incur any SLA violation during maintenance windows. +Platform maintenance shouldn't affect application uptime or availability. Applications continue to stay online while platform maintenance occurs. ++Platform maintenance might cause applications to be cold started on new virtual machines, which can lead to delays. An application is still considered to be online while it's cold starting. To minimize or avoid cold starts, consider using [local cache for Windows apps](overview-local-cache.md) and [health check](monitor-instances-health-check.md). ++We don't expect sites to incur any service-level agreement (SLA) violations during the maintenance windows. -### How does the upgrade work how does it ensure the smooth operation of my apps? +### How does the upgrade ensure the smooth operation of my apps? -Azure App Service represents a fleet of scale units, which provide hosting of web applications/solutions to the customers. Each scale unit is further divided into smaller pieces and sliced into a concept of upgrade domains and availability zones. This is to optimize placements of bigger App Service Plans and smooth deployments since not all machines in each scale unit are updated at once. Fleet upgrades machines iteratively while monitoring the health of the fleet so any time there is an issue, the system can stop the rollout. This process is described in detail at [Demystifying the magic behind App Service OS updates - Azure App Service](https://azure.github.io/AppService/2018/01/18/Demystifying-the-magic-behind-App-Service-OS-updates.html). +Azure App Service represents a fleet of scale units that provide hosting of web applications and solutions to customers. Each scale unit is divided into upgrade domains and availability zones. This division optimizes placements of bigger App Service plans and smooth deployments, because not all machines in each scale unit are updated at once. ++Maintenance operations upgrade machines iteratively while App Service monitors the health of the fleet. If there's a problem, the system can stop the rollout. For more information about this process, see the blog post [Demystifying the magic behind App Service OS updates](https://azure.github.io/AppService/2018/01/18/Demystifying-the-magic-behind-App-Service-OS-updates.html). ### Are business hours reflected? -Maintenance operations are optimized to start outside standard business hours (9-5pm) as statistically that is a better timing for any interruptions and restarts of workloads as there is a less stress on the system (in customer applications and transitively also on the platform itself). For App Service Plan and App Service Environment v2, maintenance can continue into business hours during longer maintenance events. +Maintenance operations are optimized to start outside the standard business hours of 9 AM to 5 PM. Statistically, that's the best time for any interruptions and restarts of workloads because there's less stress on the system (in customer applications and transitively on the platform itself). For App Service plans and App Service Environment v2, maintenance can continue into business hours during longer maintenance events. ### What are my options to control routine maintenance? -If you run your workloads in Isolated SKU via App Service Environment v3, you can also schedule the upgrades when needed. This is described with details at Control and automate planned maintenance for App Service Environment v3 - Azure App Service. +If you run your workloads in an isolated product via App Service Environment v3, you can schedule the upgrades if necessary. For more information about this capability, see the blog post [Control and automate planned maintenance for App Service Environment v3](https://azure.github.io/AppService/2022/09/15/Configure-automation-for-upgrade-preferences-in-App-Service-Environment.html). ### Can I prepare my apps better for restarts? -If your applications need extra time during restarts to come online (a typical pattern would be heavy dependency on external resources during application warm-up/start-up), consider using [Health Check](monitor-instances-health-check.md). You can use this to communicate with the platform that your application is not ready to receive requests yet and the system can use that information to route requests to other instances in your App Service Plan. For such case, it's recommended to have at least two instances in the plan. --### My applications have been online, but since these notifications started showing up things are worse. What changed? +If your applications need extra time during restarts to come online, consider using [health check](monitor-instances-health-check.md). A typical pattern for needing extra time is heavy dependency on external resources during application warmup or startup. -Updates and maintenance events have been happening to the platform since its inception. The frequency of updates decreased over time, so the number of interruptions also decreased and uptime increases. However, there is an increased level of visibility into all changes which can cause the perception that more changes are being made. +You can use health check to inform the platform that your application isn't ready to receive requests yet. The system can use that information to route requests to other instances in your App Service plan. For such cases, we recommend that you have at least two instances in the plan. -## Next steps +### My applications have been online, but things are worse since these notifications started showing up. What changed? -[Control and automate planned maintenance for App Service Environment v3 - Azure App Service](https://azure.github.io/AppService/2022/09/15/Configure-automation-for-upgrade-preferences-in-App-Service-Environment.html) +Updates and maintenance events have been happening to the platform since its inception. The frequency of updates decreased over time, so the number of interruptions also decreased and uptime increased. However, you now have more visibility into all changes. Increased visibility might cause the perception that more changes are happening. -[Demystifying the magic behind App Service OS updates - Azure App Service](https://azure.github.io/AppService/2018/01/18/Demystifying-the-magic-behind-App-Service-OS-updates.html) +## Next steps -[Routine Planned Maintenance Notifications for Azure App Service - Azure App Service](https://azure.github.io/AppService/2022/02/01/App-Service-Planned-Notification-Feature.html) +Get more information about maintenance notifications by reading the blog post [Routine Planned Maintenance Notifications for Azure App Service](https://azure.github.io/AppService/2022/02/01/App-Service-Planned-Notification-Feature.html). |
app-service | Tutorial Java Quarkus Postgresql App | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/app-service/tutorial-java-quarkus-postgresql-app.md | |
application-gateway | Application Gateway Backend Health Troubleshooting | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/application-gateway/application-gateway-backend-health-troubleshooting.md | |
automation | Automation Runbook Output And Messages | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/automation/automation-runbook-output-and-messages.md | |
automation | Automation Tutorial Runbook Textual | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/automation/learn/automation-tutorial-runbook-textual.md | |
azure-arc | Extensions Troubleshooting | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-arc/kubernetes/extensions-troubleshooting.md | Title: "Troubleshoot extension issues for Azure Arc-enabled Kubernetes clusters" Last updated 12/19/2023 + description: "Learn how to resolve common issues with Azure Arc-enabled Kubernetes cluster extensions." |
azure-arc | Tutorial Gitops Flux2 Ci Cd | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-arc/kubernetes/tutorial-gitops-flux2-ci-cd.md | For the details on installation, refer to the [GitOps Connector](https://github. | Variable | Value | | -- | -- |-| AZ_ACR_NAME | (your Azure Container Registry instance, for example. azurearctest.azurecr.io) | | AZURE_SUBSCRIPTION | (your Azure Service Connection, which should be **arc-demo-acr** from earlier in the tutorial) | | AZ_ACR_NAME | Azure ACR name, for example arc-demo-acr | | ENVIRONMENT_NAME | Dev | |
azure-arc | Administer Arc Scvmm | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-arc/system-center-virtual-machine-manager/administer-arc-scvmm.md | |
azure-arc | Remove Vcenter From Arc Vmware | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-arc/vmware-vsphere/remove-vcenter-from-arc-vmware.md | |
azure-functions | Durable Functions Orchestrations | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-functions/durable/durable-functions-orchestrations.md | public static async Task<object> RunOrchestrator( [FunctionName("CourseRecommendations")] public static async Task<object> Mapper(- [ActivityTrigger] (string Major, int UniversityYear) inputs, FunctionContext executionContext) + [ActivityTrigger] (string Major, int UniversityYear) studentInfo, FunctionContext executionContext) { // retrieve and return course recommendations by major and university year return new |
azure-functions | Functions Bindings Azure Sql Input | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-functions/functions-bindings-azure-sql-input.md | The examples refer to a `ToDoItem` class and a corresponding database table: <a id="http-trigger-look-up-id-from-query-string-c-oop"></a> ### HTTP trigger, get row by ID from query string -The following example shows a [C# function](functions-dotnet-class-library.md) that retrieves a single record. The function is triggered by an HTTP request that uses a query string to specify the ID. That ID is used to retrieve a `ToDoItem` record with the specified query. +The following example shows a [C# function](functions-dotnet-class-library.md) that retrieves a single record. The function is [triggered by an HTTP request](./functions-bindings-http-webhook-trigger.md) that uses a query string to specify the ID. That ID is used to retrieve a `ToDoItem` record with the specified query. > [!NOTE] > The HTTP query string parameter is case-sensitive. namespace AzureSQLSamples <a id="http-trigger-get-multiple-items-from-route-data-c-oop"></a> ### HTTP trigger, get multiple rows from route parameter -The following example shows a [C# function](functions-dotnet-class-library.md) that retrieves documents returned by the query. The function is triggered by an HTTP request that uses route data to specify the value of a query parameter. That parameter is used to filter the `ToDoItem` records in the specified query. +The following example shows a [C# function](functions-dotnet-class-library.md) that retrieves documents returned by the query. The function is [triggered by an HTTP request](./functions-bindings-http-webhook-trigger.md) that uses route data to specify the value of a query parameter. That parameter is used to filter the `ToDoItem` records in the specified query. ```cs using System.Collections.Generic; The examples refer to a `ToDoItem` class and a corresponding database table: <a id="http-trigger-look-up-id-from-query-string-c"></a> ### HTTP trigger, get row by ID from query string -The following example shows a [C# function](functions-dotnet-class-library.md) that retrieves a single record. The function is triggered by an HTTP request that uses a query string to specify the ID. That ID is used to retrieve a `ToDoItem` record with the specified query. +The following example shows a [C# function](functions-dotnet-class-library.md) that retrieves a single record. The function is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request that uses a query string to specify the ID. That ID is used to retrieve a `ToDoItem` record with the specified query. > [!NOTE] > The HTTP query string parameter is case-sensitive. namespace AzureSQLSamples <a id="http-trigger-get-multiple-items-from-route-data-c"></a> ### HTTP trigger, get multiple rows from route parameter -The following example shows a [C# function](functions-dotnet-class-library.md) that retrieves documents returned by the query. The function is triggered by an HTTP request that uses route data to specify the value of a query parameter. That parameter is used to filter the `ToDoItem` records in the specified query. +The following example shows a [C# function](functions-dotnet-class-library.md) that retrieves documents returned by the query. The function is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request that uses route data to specify the value of a query parameter. That parameter is used to filter the `ToDoItem` records in the specified query. ```cs using System.Collections.Generic; public class ToDoItem { <a id="http-trigger-get-multiple-items-java"></a> ### HTTP trigger, get multiple rows -The following example shows a SQL input binding in a Java function that reads from a query and returns the results in the HTTP response. +The following example shows a SQL input binding in a Java function that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and reads from a query and returns the results in the HTTP response. ```java package com.function; public class GetToDoItems { <a id="http-trigger-look-up-id-from-query-string-java"></a> ### HTTP trigger, get row by ID from query string -The following example shows a SQL input binding in a Java function that reads from a query filtered by a parameter from the query string and returns the row in the HTTP response. +The following example shows a SQL input binding in a Java function that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and reads from a query filtered by a parameter from the query string and returns the row in the HTTP response. ```java public class GetToDoItem { public class GetToDoItem { <a id="http-trigger-delete-one-or-multiple-rows-java"></a> ### HTTP trigger, delete rows -The following example shows a SQL input binding in a Java function that executes a stored procedure with input from the HTTP request query parameter. +The following example shows a SQL input binding in a Java function that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and executes a stored procedure with input from the HTTP request query parameter. The stored procedure `dbo.DeleteToDo` must be created on the database. In this example, the stored procedure deletes a single record or all records depending on the value of the parameter. The examples refer to a database table: <a id="http-trigger-get-multiple-items-javascript"></a> ### HTTP trigger, get multiple rows -The following example shows a SQL input binding that reads from a query and returns the results in the HTTP response. +The following example shows a SQL input binding that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and reads from a query and returns the results in the HTTP response. ::: zone-end ::: zone pivot="programming-language-typescript" module.exports = async function (context, req, todoItems) { <a id="http-trigger-look-up-id-from-query-string-javascript"></a> ### HTTP trigger, get row by ID from query string -The following example shows a SQL input binding that reads from a query filtered by a parameter from the query string and returns the row in the HTTP response. +The following example shows a SQL input binding that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and reads from a query filtered by a parameter from the query string and returns the row in the HTTP response. ::: zone-end ::: zone pivot="programming-language-typescript" module.exports = async function (context, req, todoItem) { <a id="http-trigger-delete-one-or-multiple-rows-javascript"></a> ### HTTP trigger, delete rows -The following example shows a SQL input binding that executes a stored procedure with input from the HTTP request query parameter. +The following example shows a SQL input binding that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and executes a stored procedure with input from the HTTP request query parameter. The stored procedure `dbo.DeleteToDo` must be created on the database. In this example, the stored procedure deletes a single record or all records depending on the value of the parameter. The examples refer to a database table: <a id="http-trigger-get-multiple-items-powershell"></a> ### HTTP trigger, get multiple rows -The following example shows a SQL input binding in a function.json file and a PowerShell function that reads from a query and returns the results in the HTTP response. +The following example shows a SQL input binding in a function.json file and a PowerShell function that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and reads from a query and returns the results in the HTTP response. The following is binding data in the function.json file: Push-OutputBinding -Name res -Value ([HttpResponseContext]@{ <a id="http-trigger-look-up-id-from-query-string-powershell"></a> ### HTTP trigger, get row by ID from query string -The following example shows a SQL input binding in a PowerShell function that reads from a query filtered by a parameter from the query string and returns the row in the HTTP response. +The following example shows a SQL input binding in a PowerShell function that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and reads from a query filtered by a parameter from the query string and returns the row in the HTTP response. The following is binding data in the function.json file: Push-OutputBinding -Name res -Value ([HttpResponseContext]@{ <a id="http-trigger-delete-one-or-multiple-rows-powershell"></a> ### HTTP trigger, delete rows -The following example shows a SQL input binding in a function.json file and a PowerShell function that executes a stored procedure with input from the HTTP request query parameter. +The following example shows a SQL input binding in a function.json file and a PowerShell function that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and executes a stored procedure with input from the HTTP request query parameter. The stored procedure `dbo.DeleteToDo` must be created on the database. In this example, the stored procedure deletes a single record or all records depending on the value of the parameter. The examples refer to a database table: <a id="http-trigger-get-multiple-items-python"></a> ### HTTP trigger, get multiple rows -The following example shows a SQL input binding in a function.json file and a Python function that reads from a query and returns the results in the HTTP response. +The following example shows a SQL input binding in a function.json file and a Python function that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and reads from a query and returns the results in the HTTP response. The following is binding data in the function.json file: def main(req: func.HttpRequest, todoItems: func.SqlRowList) -> func.HttpResponse <a id="http-trigger-look-up-id-from-query-string-python"></a> ### HTTP trigger, get row by ID from query string -The following example shows a SQL input binding in a Python function that reads from a query filtered by a parameter from the query string and returns the row in the HTTP response. +The following example shows a SQL input binding in a Python function that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and reads from a query filtered by a parameter from the query string and returns the row in the HTTP response. The following is binding data in the function.json file: def main(req: func.HttpRequest, todoItem: func.SqlRowList) -> func.HttpResponse: <a id="http-trigger-delete-one-or-multiple-rows-python"></a> ### HTTP trigger, delete rows -The following example shows a SQL input binding in a function.json file and a Python function that executes a stored procedure with input from the HTTP request query parameter. +The following example shows a SQL input binding in a function.json file and a Python function that is [triggered by an HTTP](./functions-bindings-http-webhook-trigger.md) request and executes a stored procedure with input from the HTTP request query parameter. The stored procedure `dbo.DeleteToDo` must be created on the database. In this example, the stored procedure deletes a single record or all records depending on the value of the parameter. If an exception occurs when a SQL input binding is executed then the function co - [Save data to a database (Output binding)](./functions-bindings-azure-sql-output.md) - [Run a function when data is changed in a SQL table (Trigger)](./functions-bindings-azure-sql-trigger.md)+- [Run a function from a HTTP request (trigger)](./functions-bindings-http-webhook-trigger.md) - [Review ToDo API sample with Azure SQL bindings](/samples/azure-samples/azure-sql-binding-func-dotnet-todo/todo-backend-dotnet-azure-sql-bindings-azure-functions/) |
azure-functions | Functions Reference | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-functions/functions-reference.md | To use an identity-based connection for `AzureWebJobsStorage`, configure the fol [Common properties for identity-based connections](#common-properties-for-identity-based-connections) may also be set as well. -If you're configuring `AzureWebJobsStorage` using a storage account that uses the default DNS suffix and service name for global Azure, following the `https://<accountName>.blob/queue/file/table.core.windows.net` format, you can instead set `AzureWebJobsStorage__accountName` to the name of your storage account. The endpoints for each storage service are inferred for this account. This doesn't work when the storage account is in a sovereign cloud or has a custom DNS. +If you're configuring `AzureWebJobsStorage` using a storage account that uses the default DNS suffix and service name for global Azure, following the `https://<accountName>.[blob|queue|file|table].core.windows.net` format, you can instead set `AzureWebJobsStorage__accountName` to the name of your storage account. The endpoints for each storage service are inferred for this account. This doesn't work when the storage account is in a sovereign cloud or has a custom DNS. | Setting | Description | Example value | |--|--|| |
azure-functions | Functions Scale | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-functions/functions-scale.md | The Azure Functions hosting plan you choose dictates the following behaviors: * The resources available to each function app instance. * Support for advanced functionality, such as Azure Virtual Network connectivity. -In addition to Azure Functions hosting, you can also host containerized function apps in containers can also be deployed to Kubernetes clusters and to Azure Container Apps. If you choose to host your functions in a Kubernetes cluster, consider using an [Azure Arc-enabled Kubernetes cluster](../azure-arc/kubernetes/overview.md). To learn more about deploying custom container apps, see [Azure Container Apps hosting of Azure Functions](./functions-container-apps-hosting.md). +In addition to Azure Functions hosting, you can also host containerized function apps in containers that can be deployed to Kubernetes clusters or to Azure Container Apps. If you choose to host your functions in a Kubernetes cluster, consider using an [Azure Arc-enabled Kubernetes cluster](../azure-arc/kubernetes/overview.md). To learn more about deploying custom container apps, see [Azure Container Apps hosting of Azure Functions](./functions-container-apps-hosting.md). This article provides a detailed comparison between the various hosting plans, including container-based hosting options. |
azure-functions | Migrate Dotnet To Isolated Model | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-functions/migrate-dotnet-to-isolated-model.md | $AppInfo = @{} foreach ($App in $FunctionApps) {- if ($App.ApplicationSettings["FUNCTIONS_WORKER_RUNTIME"] -eq 'dotnet') + if ($App.Runtime -eq 'dotnet') {- $AppInfo.Add($App.Name, $App.ApplicationSettings["FUNCTIONS_WORKER_RUNTIME"]) + $AppInfo.Add($App.Name, $App.Runtime) } } |
azure-functions | Streaming Logs | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-functions/streaming-logs.md | Title: Stream execution logs in Azure Functions description: Learn how you can stream logs for functions in near real time. Last updated 8/21/2023 -+ ms.devlang: azurecli # Customer intent: As a developer, I want to be able to configure streaming logs so that I can see what's happening in my functions in near real time. |
azure-functions | Update Language Versions | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-functions/update-language-versions.md | Title: Update language versions in Azure Functions description: Learn how to update the version of the native language used by a function app in Azure Functions. -+ Last updated 12/06/2023 zone_pivot_groups: programming-languages-set-functions |
azure-linux | Quickstart Azure Powershell | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-linux/quickstart-azure-powershell.md | description: Learn how to quickly create an Azure Linux Container Host for an AK + Last updated 11/20/2023 |
azure-monitor | Alerts Create Rule Cli Powershell Arm | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/alerts/alerts-create-rule-cli-powershell-arm.md | description: This article shows you how to create a new alert rule using the CLI + Last updated 01/03/2024 |
azure-monitor | Container Insights Agent Config | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-agent-config.md | - Title: Configure Container insights agent data collection | Microsoft Docs -description: This article describes how you can configure the Container insights agent to control stdout/stderr and environment variables log collection. - Previously updated : 11/14/2023----# Configure agent data collection for Container insights --Container insights collects stdout, stderr, and environmental variables from container workloads deployed to managed Kubernetes clusters from the containerized agent. You can configure agent data collection settings by creating a custom Kubernetes ConfigMap to control this experience. --This article demonstrates how to create ConfigMaps and configure data collection based on your requirements. --## ConfigMap file settings overview --A template ConfigMap file is provided so that you can easily edit it with your customizations without having to create it from scratch. Before you start, review the Kubernetes documentation about [ConfigMaps](https://kubernetes.io/docs/tasks/configure-pod-container/configure-pod-configmap/). Familiarize yourself with how to create, configure, and deploy ConfigMaps. You need to know how to filter stderr and stdout per namespace or across the entire cluster. You also need to know how to filter environment variables for any container running across all pods/nodes in the cluster. -->[!IMPORTANT] ->The minimum agent version supported to collect stdout, stderr, and environmental variables from container workloads is **ciprod06142019** or later. To verify your agent version, on the **Node** tab, select a node. On the **Properties** pane, note the value of the **Agent Image Tag** property. For more information about the agent versions and what's included in each release, see [Agent release notes](https://github.com/microsoft/Docker-Provider/tree/ci_feature_prod). --### Data collection settings --The following table describes the settings you can configure to control data collection. -->[!NOTE] ->For clusters enabling container insights using Azure CLI version 2.54.0 or greater, the default setting for `[log_collection_settings.schema]` will be set to "v2" --| Key | Data type | Value | Description | -|--|--|--|--| -| `schema-version` | String (case sensitive) | v1 | This schema version is used by the agent<br> when parsing this ConfigMap.<br> Currently supported schema-version is v1.<br> Modifying this value isn't supported and will be<br> rejected when the ConfigMap is evaluated. | -| `config-version` | String | | Supports the ability to keep track of this config file's version in your source control system/repository.<br> Maximum allowed characters are 10, and all other characters are truncated. | -| `[log_collection_settings.stdout] enabled =` | Boolean | True or false | Controls if stdout container log collection is enabled. When set to `true` and no namespaces are excluded for stdout log collection<br> (`log_collection_settings.stdout.exclude_namespaces` setting), stdout logs will be collected from all containers across all pods/nodes in the cluster. If not specified in the ConfigMap,<br> the default value is `enabled = true`. | -| `[log_collection_settings.stdout] exclude_namespaces =` | String | Comma-separated array | Array of Kubernetes namespaces for which stdout logs won't be collected. This setting is effective only if<br> `log_collection_settings.stdout.enabled`<br> is set to `true`.<br> If not specified in the ConfigMap, the default value is<br> `exclude_namespaces = ["kube-system","gatekeeper-system"]`. | -| `[log_collection_settings.stderr] enabled =` | Boolean | True or false | Controls if stderr container log collection is enabled.<br> When set to `true` and no namespaces are excluded for stdout log collection<br> (`log_collection_settings.stderr.exclude_namespaces` setting), stderr logs will be collected from all containers across all pods/nodes in the cluster.<br> If not specified in the ConfigMap, the default value is<br> `enabled = true`. | -| `[log_collection_settings.stderr] exclude_namespaces =` | String | Comma-separated array | Array of Kubernetes namespaces for which stderr logs won't be collected.<br> This setting is effective only if<br> `log_collection_settings.stdout.enabled` is set to `true`.<br> If not specified in the ConfigMap, the default value is<br> `exclude_namespaces = ["kube-system","gatekeeper-system"]`. | -| `[log_collection_settings.env_var] enabled =` | Boolean | True or false | This setting controls environment variable collection<br> across all pods/nodes in the cluster<br> and defaults to `enabled = true` when not specified<br> in the ConfigMap.<br> If collection of environment variables is globally enabled, you can disable it for a specific container<br> by setting the environment variable<br> `AZMON_COLLECT_ENV` to `False` either with a Dockerfile setting or in the [configuration file for the Pod](https://kubernetes.io/docs/tasks/inject-data-application/define-environment-variable-container/) under the `env:` section.<br> If collection of environment variables is globally disabled, you can't enable collection for a specific container. The only override that can be applied at the container level is to disable collection when it's already enabled globally. | -| `[log_collection_settings.enrich_container_logs] enabled =` | Boolean | True or false | This setting controls container log enrichment to populate the `Name` and `Image` property values<br> for every log record written to the **ContainerLog** table for all container logs in the cluster.<br> It defaults to `enabled = false` when not specified in the ConfigMap. | -| `[log_collection_settings.collect_all_kube_events] enabled =` | Boolean | True or false | This setting allows the collection of Kube events of all types.<br> By default, the Kube events with type **Normal** aren't collected. When this setting is set to `true`, the **Normal** events are no longer filtered, and all events are collected.<br> It defaults to `enabled = false` when not specified in the ConfigMap. | -| `[log_collection_settings.schema] enabled =` | String (case sensitive) | v2 or v1 [(retired)](./container-insights-v2-migration.md) | This setting sets the log ingestion format to ContainerLogV2 | -| `[log_collection_settings.enable_multiline_logs] enabled =` | Boolean | True or False | This setting controls whether multiline container logs are enabled. They are disabled by default. See [Multi-line logging in Container Insights](./container-insights-logging-v2.md) to learn more. | --### Metric collection settings --The following table describes the settings you can configure to control metric collection. --| Key | Data type | Value | Description | -|--|--|--|--| -| `[metric_collection_settings.collect_kube_system_pv_metrics] enabled =` | Boolean | True or false | This setting allows persistent volume (PV) usage metrics to be collected in the kube-system namespace. By default, usage metrics for persistent volumes with persistent volume claims in the kube-system namespace aren't collected. When this setting is set to `true`, PV usage metrics for all namespaces are collected. By default, this setting is set to `false`. | --ConfigMap is a global list and there can be only one ConfigMap applied to the agent. You can't have another ConfigMap overruling the collections. --### Agent settings for outbound proxy with Azure Monitor Private Link Scope (AMPLS) --| Key | Data type | Value | Description | -|--|--|--|--| -| `[agent_settings.proxy_config] ignore_proxy_settings =` | Boolean | True or false | Set this value to true to ignore proxy settings. On both AKS & Arc K8s environments, if your cluster is configured with forward proxy, then proxy settings are automatically applied and used for the agent. For certain configurations, such as, with AMPLS + Proxy, you might with for the proxy config to be ignored. . By default, this setting is set to `false`. | --## Configure and deploy ConfigMaps --To configure and deploy your ConfigMap configuration file to your cluster: --1. Download the [template ConfigMap YAML file](https://aka.ms/container-azm-ms-agentconfig) and save it as *container-azm-ms-agentconfig.yaml*. --1. Edit the ConfigMap YAML file with your customizations to collect stdout, stderr, and environmental variables: -- - To exclude specific namespaces for stdout log collection, configure the key/value by using the following example: - `[log_collection_settings.stdout] enabled = true exclude_namespaces = ["my-namespace-1", "my-namespace-2"]`. - - To disable environment variable collection for a specific container, set the key/value `[log_collection_settings.env_var] enabled = true` to enable variable collection globally. Then follow the steps [here](container-insights-manage-agent.md#disable-environment-variable-collection-on-a-container) to complete configuration for the specific container. - - To disable stderr log collection cluster-wide, configure the key/value by using the following example: `[log_collection_settings.stderr] enabled = false`. - - Save your changes in the editor. --1. Create a ConfigMap by running the following kubectl command: `kubectl apply -f <configmap_yaml_file.yaml>`. - - Example: `kubectl apply -f container-azm-ms-agentconfig.yaml` --The configuration change can take a few minutes to finish before taking effect. Then all Azure Monitor Agent pods in the cluster will restart. The restart is a rolling restart for all Azure Monitor Agent pods, so not all of them restart at the same time. When the restarts are finished, a message similar to this example includes the following result: `configmap "container-azm-ms-agentconfig" created`. ---## Verify configuration --To verify the configuration was successfully applied to a cluster, use the following command to review the logs from an agent pod: `kubectl logs ama-logs-fdf58 -n kube-system`. If there are configuration errors from the Azure Monitor Agent pods, the output will show errors similar to the following example: --``` -***************Start Config Processing******************** -config::unsupported/missing config schema version - 'v21' , using defaults -``` --Errors related to applying configuration changes are also available for review. The following options are available to perform more troubleshooting of configuration changes: --- From an agent pod log by using the same `kubectl logs` command.-- From live logs. Live logs show errors similar to the following example:-- ``` - config::error::Exception while parsing config map for log collection/env variable settings: \nparse error on value \"$\" ($end), using defaults, please check config map for errors - ``` --- From the **KubeMonAgentEvents** table in your Log Analytics workspace. Data is sent every hour with error severity for configuration errors. If there are no errors, the entry in the table will have data with severity info, which reports no errors. The **Tags** property contains more information about the pod and container ID on which the error occurred and also the first occurrence, last occurrence, and count in the last hour.--After you correct the errors in the ConfigMap, save the YAML file and apply the updated ConfigMap by running the following command: `kubectl apply -f <configmap_yaml_file.yaml`. --## Apply updated ConfigMap --If you've already deployed a ConfigMap on clusters and you want to update it with a newer configuration, you can edit the ConfigMap file you've previously used. Then you can apply it by using the same command as before: `kubectl apply -f <configmap_yaml_file.yaml`. --The configuration change can take a few minutes to finish before taking effect. Then all Azure Monitor Agent pods in the cluster will restart. The restart is a rolling restart for all Azure Monitor Agent pods, so not all of them restart at the same time. When the restarts are finished, a message similar to this example includes the following result: `configmap "container-azm-ms-agentconfig" updated`. --## Verify schema version --Supported config schema versions are available as pod annotation (schema-versions) on the Azure Monitor Agent pod. You can see them with the following kubectl command: `kubectl describe pod ama-logs-fdf58 -n=kube-system`. --Output similar to the following example appears with the annotation schema-versions: --``` - Name: ama-logs-fdf58 - Namespace: kube-system - Node: aks-agentpool-95673144-0/10.240.0.4 - Start Time: Mon, 10 Jun 2019 15:01:03 -0700 - Labels: controller-revision-hash=589cc7785d - dsName=ama-logs-ds - pod-template-generation=1 - Annotations: agentVersion=1.10.0.1 - dockerProviderVersion=5.0.0-0 - schema-versions=v1 -``` --## Frequently asked questions --This section provides answers to common questions. --### How do I enable log collection for containers in the kube-system namespace through Helm? --The log collection from containers in the kube-system namespace is disabled by default. You can enable log collection by setting an environment variable on Azure Monitor Agent. See the [Container insights](https://aka.ms/azuremonitor-containers-helm-chart) GitHub page. - ---## Next steps --- Container insights doesn't include a predefined set of alerts. Review the [Create performance alerts with Container insights](./container-insights-log-alerts.md) to learn how to create recommended alerts for high CPU and memory utilization to support your DevOps or operational processes and procedures.-- With monitoring enabled to collect health and resource utilization of your Azure Kubernetes Service or hybrid cluster and workloads running on them, learn [how to use](container-insights-analyze.md) Container insights.-- View [log query examples](container-insights-log-query.md) to see predefined queries and examples to evaluate or customize for alerting, visualizing, or analyzing your clusters. |
azure-monitor | Container Insights Analyze | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-analyze.md | Use the workbooks, performance charts, and health status in Container insights t This article helps you understand the two perspectives and how Azure Monitor helps you quickly assess, investigate, and resolve detected issues. -The main differences in monitoring a Windows Server cluster with Container insights compared to a Linux cluster are described in [Features of Container insights](container-insights-overview.md#features-of-container-insights) in the overview article. - ## Workbooks |
azure-monitor | Container Insights Cost | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-cost.md | The Azure Monitor pricing model is primarily based on the amount of data ingeste The following types of data collected from a Kubernetes cluster with Container insights influence cost and can be customized based on your usage: - Perf, Inventory, InsightsMetrics, and KubeEvents can be controlled through [cost optimization settings](../containers/container-insights-cost-config.md)-- Stdout and stderr container logs from every monitored container in every Kubernetes namespace in the cluster via the [agent ConfigMap](../containers/container-insights-agent-config.md)+- Stdout and stderr container logs from every monitored container in every Kubernetes namespace in the cluster via the [agent ConfigMap](../containers/container-insights-data-collection-configmap.md) - Container environment variables from every monitored container in the cluster - Completed Kubernetes jobs/pods in the cluster that don't require monitoring - Active scraping of Prometheus metrics Otherwise, the majority of your data belongs to the ContainerLog table. and you ### Reducing your ContainerLog costs -After you finish your analysis to determine which sources are generating the data that's exceeding your requirements, you can reconfigure data collection. For more information on configuring collection of stdout, stderr, and environmental variables, see [Configure agent data collection settings](container-insights-agent-config.md). +After you finish your analysis to determine which sources are generating the data that's exceeding your requirements, you can reconfigure data collection. For more information on configuring collection of stdout, stderr, and environmental variables, see [Configure agent data collection settings](container-insights-data-collection-configmap.md). The following examples show what changes you can apply to your cluster by modifying the ConfigMap file to help control cost. After you apply one or more of these changes to your ConfigMaps, apply it to you You can save on data ingestion costs on ContainerLog in your Log Analytics workspace that you primarily use for debugging, troubleshooting, and auditing as Basic Logs. For more information, including the limitations of Basic Logs, see [Configure Basic Logs in Azure Monitor](../logs/basic-logs-configure.md). ContainerLogV2 is the configured version of Basic Logs that Container Insights uses. ContainerLogV2 includes verbose text-based log records. -You must be on the ContainerLogV2 schema to configure Basic Logs. For more information, see [Enable the ContainerLogV2 schema (preview)](container-insights-logging-v2.md). +You must be on the ContainerLogV2 schema to configure Basic Logs. For more information, see [Enable the ContainerLogV2 schema (preview)](container-insights-logs-schema.md). ### Prometheus metrics scraping > [!NOTE] -> This section describes [collection of Prometheus metrics in your Log Analytics workspace](container-insights-prometheus-logs.md). This information does not apply if you're using [Managed Prometheus to scrape your Prometheus metrics](prometheus-metrics-enable.md). +> This section describes [collection of Prometheus metrics in your Log Analytics workspace](container-insights-prometheus-logs.md). This information does not apply if you're using [Managed Prometheus to scrape your Prometheus metrics](kubernetes-monitoring-enable.md#enable-prometheus-and-grafana). If you [collect Prometheus metrics in your Log Analytics workspace](container-insights-prometheus-logs.md), make sure that you limit the number of metrics you collect from your cluster: |
azure-monitor | Container Insights Data Collection Configmap | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-data-collection-configmap.md | + + Title: Configure Container insights data collection using ConfigMap +description: Describes how you can configure other data collection for Container insights using ConfigMap. + Last updated : 12/19/2023++++# Configure data collection in Container insights using ConfigMap ++This article describes how to configure data collection in Container insights using ConfigMap. [ConfigMaps](https://kubernetes.io/docs/tasks/configure-pod-container/configure-pod-configmap/) are a Kubernetes mechanism that allow you to store non-confidential data such as configuration file or environment variables. ++The ConfigMap is primarily used to configure data collection of the container logs and environment variables of the cluster. You can individually configure the stdout and stderr logs and also enable multiline logging. ++Specific configuration you can perform with the ConfigMap includes: ++- Enable/disable and namespace filtering for stdout and stderr logs +- Enable/disable collection of environment variables for the cluster +- Filter for Normal Kube events +- Select log schema +- Enable/disable multiline logging +- Ignore proxy settings ++> [!NOTE] +> See [Configure data collection in Container insights using data collection rule](./container-insights-data-collection-dcr.md) to configure data collection using a DCR which allows you to configure different settings. ++## Prerequisites +- ConfigMap is a global list and there can be only one ConfigMap applied to the agent for Container insights. Applying another ConfigMap will overrule the previous ConfigMap collection settings. +- The minimum agent version supported to collect stdout, stderr, and environmental variables from container workloads is **ciprod06142019** or later. To verify your agent version, on the **Node** tab, select a node. On the **Properties** pane, note the value of the **Agent Image Tag** property. For more information about the agent versions and what's included in each release, see [Agent release notes](https://github.com/microsoft/Docker-Provider/tree/ci_feature_prod). ++## Configure and deploy ConfigMap ++Use the following procedure to configure and deploy your ConfigMap configuration file to your cluster: ++1. Download the [template ConfigMap YAML file](https://aka.ms/container-azm-ms-agentconfig) and open it in an editor. If you already have a ConfigMap file, then you can use that one. +1. Edit the ConfigMap YAML file with your customizations to collect stdout, stderr, and environmental variables: ++ - To exclude specific namespaces for stdout log collection, configure the key/value by using the following example: + `[log_collection_settings.stdout] enabled = true exclude_namespaces = ["my-namespace-1", "my-namespace-2"]`. + - To disable environment variable collection for a specific container, set the key/value `[log_collection_settings.env_var] enabled = true` to enable variable collection globally. Then follow the steps [here](container-insights-manage-agent.md#disable-environment-variable-collection-on-a-container) to complete configuration for the specific container. + - To disable stderr log collection cluster-wide, configure the key/value by using the following example: `[log_collection_settings.stderr] enabled = false`. + +3. Save your changes in the editor. ++1. Create a ConfigMap by running the following kubectl command: ++ ```azurecli + kubectl apply -f <configmap_yaml_file.yaml> + ``` + + Example: + + ```output + kubectl apply -f container-azm-ms-agentconfig.yaml + ``` +++ The configuration change can take a few minutes to finish before taking effect. Then all Azure Monitor Agent pods in the cluster will restart. The restart is a rolling restart for all Azure Monitor Agent pods, so not all of them restart at the same time. When the restarts are finished, you'll receive a message similar to the following result: + + ```output + configmap "container-azm-ms-agentconfig" created`. + `````` +++### Data collection settings ++The following table describes the settings you can configure to control data collection. +++| Setting | Data type | Value | Description | +|:|:|:|:| +| `schema-version` | String (case sensitive) | v1 | Used by the agent when parsing this ConfigMap. Currently supported schema-version is v1. Modifying this value isn't supported and will be rejected when the ConfigMap is evaluated. | +| `config-version` | String | | Allows you to keep track of this config file's version in your source control system/repository. Maximum allowed characters are 10, and all other characters are truncated. | +| **[log_collection_settings]** | | | | +| `[stdout] enabled` | Boolean | true<br>false | Controls whether stdout container log collection is enabled. When set to `true` and no namespaces are excluded for stdout log collection, stdout logs will be collected from all containers across all pods and nodes in the cluster. If not specified in the ConfigMap, the default value is `true`. | +| `[stdout] exclude_namespaces` | String | Comma-separated array | Array of Kubernetes namespaces for which stdout logs won't be collected. This setting is effective only if `enabled` is set to `true`. If not specified in the ConfigMap, the default value is<br> `["kube-system","gatekeeper-system"]`. | +| `[stderr] enabled` | Boolean | true<br>false | Controls whether stderr container log collection is enabled. When set to `true` and no namespaces are excluded for stderr log collection, stderr logs will be collected from all containers across all pods and nodes in the cluster. If not specified in the ConfigMap, the default value is `true`. | +| `[stderr] exclude_namespaces` | String | Comma-separated array | Array of Kubernetes namespaces for which stderr logs won't be collected. This setting is effective only if `enabled` is set to `true`. If not specified in the ConfigMap, the default value is<br> `["kube-system","gatekeeper-system"]`. | +| `[env_var] enabled` | Boolean | true<br>false | This setting controls environment variable collection across all pods and nodes in the cluster. If not specified in the ConfigMap, the default value is `true`. If collection of environment variables is globally enabled, you can disable it for a specific container by setting the environment variable `AZMON_COLLECT_ENV` to `False` either with a Dockerfile setting or in the [configuration file for the Pod](https://kubernetes.io/docs/tasks/inject-data-application/define-environment-variable-container/) under the `env:` section. If collection of environment variables is globally disabled, you can't enable collection for a specific container. The only override that can be applied at the container level is to disable collection when it's already enabled globally. | +| `[enrich_container_logs] enabled` | Boolean | true<br>false | Controls container log enrichment to populate the `Name` and `Image` property values for every log record written to the **ContainerLogV2** or **ContainerLog** table for all container logs in the cluster. If not specified in the ConfigMap, the default value is `false`. | +| `[collect_all_kube_events] enabled` | Boolean | true<br>false| Controls whether Kube events of all types are collected. By default, the Kube events with type **Normal** aren't collected. When this setting is `true`, the **Normal** events are no longer filtered, and all events are collected. If not specified in the ConfigMap, the default value is `false`. | +| `[schema] containerlog_schema_version` | String (case sensitive) | v2<br>v1 | Sets the log ingestion format. If `v2`, the **ContainerLogV2** table is used. If `v1`, the **ContainerLog** table is used (this table has been deprecated). For clusters enabling container insights using Azure CLI version 2.54.0 or greater, the default setting is `v2`. See [Container insights log schema](./container-insights-logs-schema.md) for details. | +| `[enable_multiline_logs] enabled` | Boolean | true<br>false | Controls whether multiline container logs are enabled. See [Multi-line logging in Container Insights](./container-insights-logs-schema.md#multi-line-logging-in-container-insights) for details. If not specified in the ConfigMap, the default value is `false`. This requires the `schema` setting to be `v2`. | +| **[metric_collection_settings]** | | | | +| `[collect_kube_system_pv_metrics] enabled` | Boolean | true<br>false | Allows persistent volume (PV) usage metrics to be collected in the kube-system namespace. By default, usage metrics for persistent volumes with persistent volume claims in the kube-system namespace aren't collected. When this setting is set to `true`, PV usage metrics for all namespaces are collected. If not specified in the ConfigMap, the default value is `false`. | +| **[agent_settings]** | | | | +| `[proxy_config] ignore_proxy_settings` | Boolean | true<br>false | When `true`, proxy settings are ignored. For both AKS and Arc-enabled Kubernetes environments, if your cluster is configured with forward proxy, then proxy settings are automatically applied and used for the agent. For certain configurations, such as with AMPLS + Proxy, you might want the proxy configuration to be ignored. If not specified in the ConfigMap, the default value is `false`. | ++++## Verify configuration ++To verify the configuration was successfully applied to a cluster, use the following command to review the logs from an agent pod. ++```azurecli +kubectl logs ama-logs-fdf58 -n kube-system +``` ++If there are configuration errors from the Azure Monitor Agent pods, the output will show errors similar to the following example: ++```output +***************Start Config Processing******************** +config::unsupported/missing config schema version - 'v21' , using defaults +``` ++Errors related to applying configuration changes are also available for review. The following options are available to perform more troubleshooting of configuration changes: ++- From an agent pod log using the same `kubectl logs` command. +- From live logs. Live logs show errors similar to the following example: ++ ``` + config::error::Exception while parsing config map for log collection/env variable settings: \nparse error on value \"$\" ($end), using defaults, please check config map for errors + ``` ++- From the **KubeMonAgentEvents** table in your Log Analytics workspace. Data is sent every hour with error severity for configuration errors. If there are no errors, the entry in the table will have data with severity info, which reports no errors. The **Tags** property contains more information about the pod and container ID on which the error occurred and also the first occurrence, last occurrence, and count in the last hour. +++## Verify schema version ++Supported config schema versions are available as pod annotation (schema-versions) on the Azure Monitor Agent pod. You can see them with the following kubectl command. ++```bash +kubectl describe pod ama-logs-fdf58 -n=kube-system. +``` ++Output similar to the following example appears with the annotation schema-versions: ++```output + Name: ama-logs-fdf58 + Namespace: kube-system + Node: aks-agentpool-95673144-0/10.240.0.4 + Start Time: Mon, 10 Jun 2019 15:01:03 -0700 + Labels: controller-revision-hash=589cc7785d + dsName=ama-logs-ds + pod-template-generation=1 + Annotations: agentVersion=1.10.0.1 + dockerProviderVersion=5.0.0-0 + schema-versions=v1 +``` ++## Frequently asked questions ++### How do I enable log collection for containers in the kube-system namespace through Helm? ++The log collection from containers in the kube-system namespace is disabled by default. You can enable log collection by setting an environment variable on Azure Monitor Agent. See the [Container insights GitHub page](https://aka.ms/azuremonitor-containers-helm-chart). ++## Next steps ++- See [Configure data collection in Container insights using data collection rule](container-insights-data-collection-dcr.md) to configure data collection using DCR instead of ConfigMap. + |
azure-monitor | Container Insights Data Collection Dcr | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-data-collection-dcr.md | + + Title: Configure Container insights data collection using data collection rule +description: Describes how you can configure cost optimization and other data collection for Container insights using a data collection rule. + Last updated : 12/19/2023++++# Configure data collection in Container insights using data collection rule ++This article describes how to configure data collection in Container insights using the [data collection rule (DCR)](../essentials/data-collection-rule-overview.md) for the cluster. A DCR is created when you onboard a cluster to Container insights. This DCR is used by the containerized agent to define data collection for the cluster. ++The DCR is primarily used to configure data collection of performance and inventory data and to configure cost optimization. ++Specific configuration you can perform with the DCR includes: ++- Enable/disable collection and namespace filtering for performance and inventory data +- Define collection interval for performance and inventory data +- Enable/disable collection of stdout and stderr logs +- Enable/disable Syslog collection +- Select log schema ++> [!NOTE] +> See [Configure data collection in Container insights using ConfigMap](./container-insights-data-collection-configmap.md) to configure data collection using a DCR which allows you to configure different settings. ++## Prerequisites ++- AKS clusters must use either System or User Assigned Managed Identity. If cluster is using a Service Principal, you must [upgrade to Managed Identity](../../aks/use-managed-identity.md#enable-managed-identities-on-an-existing-aks-cluster). ++++## Configure data collection +The DCR that gets created when you enable Container insights is named *MSCI-\<cluster-region\>-\<cluster-name\>*. You can view it in the Azure portal by selecting the **Data Collection Rules** option in the **Monitor** menu in the Azure portal. Rather than directly modifying the DCR, you should use one of the methods described below to configure data collection. See [Data collection parameters](#data-collection-parameters) for details about the different available settings used by each method. ++> [!WARNING] +> The default Container insights experience depends on all the existing data streams. Removing one or more of the default streams makes the Container insights experience unavailable, and you need to use other tools such as Grafana dashboards and log queries to analyze collected data. ++## [Azure portal](#tab/portal) +You can use the Azure portal to enable cost optimization on your existing cluster after Container insights has been enabled, or you can enable Container insights on the cluster along with cost optimization. ++1. Select the cluster in the Azure portal. +2. Select the **Insights** option in the **Monitoring** section of the menu. +3. If Container insights has already been enabled on the cluster, select the **Monitoring Settings** button. If not, select **Configure Azure Monitor** and see [Enable monitoring on your Kubernetes cluster with Azure Monitor](container-insights-onboard.md) for details on enabling monitoring. ++ :::image type="content" source="media/container-insights-cost-config/monitor-settings-button.png" alt-text="Screenshot of AKS cluster with monitor settings button." lightbox="media/container-insights-cost-config/monitor-settings-button.png" ::: +++4. For AKS and Arc-enabled Kubernetes, select **Use managed identity** if you haven't yet migrated the cluster to [managed identity authentication](../containers/container-insights-onboard.md#authentication). +5. Select one of the cost presets described in [Cost presets](#cost-presets). ++ :::image type="content" source="media/container-insights-cost-config/cost-settings-onboarding.png" alt-text="Screenshot that shows the onboarding options." lightbox="media/container-insights-cost-config/cost-settings-onboarding.png" ::: ++1. If you want to customize the settings, click **Edit collection settings**. See [Data collection parameters](#data-collection-parameters) for details on each setting. For **Collected data**, see [Collected data](#collected-data) below. ++ :::image type="content" source="media/container-insights-cost-config/advanced-collection-settings.png" alt-text="Screenshot that shows the collection settings options." lightbox="media/container-insights-cost-config/advanced-collection-settings.png" ::: ++1. Click **Configure** to save the settings. +++### Cost presets +When you use the Azure portal to configure cost optimization, you can select from the following preset configurations. You can select one of these or provide your own customized settings. By default, Container insights uses the *Standard* preset. ++| Cost preset | Collection frequency | Namespace filters | Syslog collection | +| | | | | +| Standard | 1 m | None | Not enabled | +| Cost-optimized | 5 m | Excludes kube-system, gatekeeper-system, azure-arc | Not enabled | +| Syslog | 1 m | None | Enabled by default | ++### Collected data +The **Collected data** option allows you to select the tables that are populated for the cluster. This is the equivalent of the `streams` parameter when performing the configuration with CLI or ARM. If you select any option other than **All (Default)**, the Container insights experience becomes unavailable, and you must use Grafana or other methods to analyze collected data. +++| Grouping | Tables | Notes | +| | | | +| All (Default) | All standard container insights tables | Required for enabling the default Container insights visualizations | +| Performance | Perf, InsightsMetrics | | +| Logs and events | ContainerLog or ContainerLogV2, KubeEvents, KubePodInventory | Recommended if you have enabled managed Prometheus metrics | +| Workloads, Deployments, and HPAs | InsightsMetrics, KubePodInventory, KubeEvents, ContainerInventory, ContainerNodeInventory, KubeNodeInventory, KubeServices | | +| Persistent Volumes | InsightsMetrics, KubePVInventory | | ++++## [CLI](#tab/cli) ++> [!NOTE] +> Minimum version required for Azure CLI is 2.51.0. + - For AKS clusters, [aks-preview](../../aks/cluster-configuration.md#install-the-aks-preview-azure-cli-extension) version 0.5.147 or higher + - For Arc enabled Kubernetes and AKS hybrid, [k8s-extension](../../azure-arc/kubernetes/extensions.md#prerequisites) version 1.4.3 or higher ++## AKS cluster ++When you use CLI to configure monitoring for your AKS cluster, you provide the configuration as a JSON file using the following format. Each of these settings is described in [Data collection parameters](#data-collection-parameters). ++```json +{ + "interval": "1m", + "namespaceFilteringMode": "Include", + "namespaces": ["kube-system"], + "enableContainerLogV2": true, + "streams": ["Microsoft-Perf", "Microsoft-ContainerLogV2"] +} +``` ++### New AKS cluster ++Use the following command to create a new AKS cluster with monitoring enabled. This assumes a configuration file named **dataCollectionSettings.json**. ++```azcli +az aks create -g <clusterResourceGroup> -n <clusterName> --enable-managed-identity --node-count 1 --enable-addons monitoring --data-collection-settings dataCollectionSettings.json --generate-ssh-keys +``` ++### Existing AKS Cluster ++**Cluster without the monitoring addon** +Use the following command to add monitoring to an existing cluster without Container insights enabled. This assumes a configuration file named **dataCollectionSettings.json**. ++```azcli +az aks enable-addons -a monitoring -g <clusterResourceGroup> -n <clusterName> --data-collection-settings dataCollectionSettings.json +``` ++**Cluster with an existing monitoring addon** +Use the following command to add a new configuration to an existing cluster with Container insights enabled. This assumes a configuration file named **dataCollectionSettings.json**. ++```azcli +# get the configured log analytics workspace resource id +az aks show -g <clusterResourceGroup> -n <clusterName> | grep -i "logAnalyticsWorkspaceResourceID" ++# disable monitoring +az aks disable-addons -a monitoring -g <clusterResourceGroup> -n <clusterName> ++# enable monitoring with data collection settings +az aks enable-addons -a monitoring -g <clusterResourceGroup> -n <clusterName> --workspace-resource-id <logAnalyticsWorkspaceResourceId> --data-collection-settings dataCollectionSettings.json +``` ++## Arc-enabled Kubernetes cluster +Use the following command to add monitoring to an existing Arc-enabled Kubernetes cluster. See [Data collection parameters](#data-collection-parameters) for definitions of the available settings. ++```azcli +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.useAADAuth=true dataCollectionSettings='{"interval":"1m","namespaceFilteringMode": "Include", "namespaces": [ "kube-system"],"enableContainerLogV2": true,"streams": ["<streams to be collected>"]}' +``` ++>[!NOTE] +> When deploying on a Windows machine, the dataCollectionSettings field must be escaped. For example, dataCollectionSettings={\"interval\":\"1m\",\"namespaceFilteringMode\": \"Include\", \"namespaces\": [ \"kube-system\"]} instead of dataCollectionSettings='{"interval":"1m","namespaceFilteringMode": "Include", "namespaces": [ "kube-system"]}' ++## AKS hybrid Cluster +Use the following command to add monitoring to an existing AKS hybrid cluster. See [Data collection parameters](#data-collection-parameters) for definitions of the available settings. ++```azcli +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type provisionedclusters --cluster-resource-provider "microsoft.hybridcontainerservice" --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.useAADAuth=true dataCollectionSettings='{"interval":"1m","namespaceFilteringMode":"Include", "namespaces": ["kube-system"],"enableContainerLogV2": true,"streams": ["<streams to be collected>"]}' +``` ++>[!NOTE] +> When deploying on a Windows machine, the dataCollectionSettings field must be escaped. For example, dataCollectionSettings={\"interval\":\"1m\",\"namespaceFilteringMode\": \"Include\", \"namespaces\": [ \"kube-system\"]} instead of dataCollectionSettings='{"interval":"1m","namespaceFilteringMode": "Include", "namespaces": [ "kube-system"]}' +++++## [ARM](#tab/arm) +++1. Download the Azure Resource Manager template and parameter files using the following commands. See below for the template and parameter files for each cluster configuration. ++ ```bash + curl -L <template file> -o existingClusterOnboarding.json + curl -L <parameter file> -o existingClusterParam.json + ``` ++ **AKS cluster** + - Template: https://aka.ms/aks-enable-monitoring-costopt-onboarding-template-file + - Parameter: https://aka.ms/aks-enable-monitoring-costopt-onboarding-template-parameter-file ++ **Arc-enabled Kubernetes** + - Template: https://aka.ms/arc-k8s-enable-monitoring-costopt-onboarding-template-file + - Parameter: https://aka.ms/arc-k8s-enable-monitoring-costopt-onboarding-template-parameter-file ++ **AKS hybrid cluster** + - Template: https://aka.ms/existingClusterOnboarding.json + - Parameter: https://aka.ms/existingClusterParam.json ++1. Edit the values in the parameter file. See [Data collection parameters](#data-collection-parameters) for details on each setting. See below for settings unique to each cluster configuration. ++ **AKS cluster**<br> + - For _aksResourceId_ and _aksResourceLocation_, use the values on the **AKS Overview** page for the AKS cluster. ++ **Arc-enabled Kubernetes** + - For _clusterResourceId_ and _clusterResourceLocation_, use the values on the **Overview** page for the AKS hybrid cluster. ++ **AKS hybrid cluster** + - For _clusterResourceId_ and _clusterRegion_, use the values on the **Overview** page for the Arc enabled Kubernetes cluster. + +++1. Deploy the ARM template with the following commands: ++ ```azcli + az login + az account set --subscription"Cluster Subscription Name" + az deployment group create --resource-group <ClusterResourceGroupName> --template-file ./existingClusterOnboarding.json --parameters @./existingClusterParam.json + ``` +++++++## Data collection parameters ++The following table describes the supported data collection settings and the name used for each for different onboarding options. +++| Name | Description | +|:|:| +| Collection frequency<br>CLI: `interval`<br>ARM: `dataCollectionInterval` | Determines how often the agent collects data. Valid values are 1m - 30m in 1m intervals The default value is 1m. If the value is outside the allowed range, then it defaults to *1 m*. | +| Namespace filtering<br>CLI: `namespaceFilteringMode`<br>ARM: `namespaceFilteringModeForDataCollection` | *Include*: Collects only data from the values in the *namespaces* field.<br>*Exclude*: Collects data from all namespaces except for the values in the *namespaces* field.<br>*Off*: Ignores any *namespace* selections and collect data on all namespaces. +| Namespace filtering<br>CLI: `namespaces`<br>ARM: `namespacesForDataCollection` | Array of comma separated Kubernetes namespaces to collect inventory and perf data based on the _namespaceFilteringMode_.<br>For example, *namespaces = \["kube-system", "default"]* with an _Include_ setting collects only these two namespaces. With an _Exclude_ setting, the agent collects data from all other namespaces except for _kube-system_ and _default_. With an _Off_ setting, the agent collects data from all namespaces including _kube-system_ and _default_. Invalid and unrecognized namespaces are ignored. | +| Enable ContainerLogV2<br>CLI: `enableContainerLogV2`<br>ARM: `enableContainerLogV2` | Boolean flag to enable ContainerLogV2 schema. If set to true, the stdout/stderr Logs are ingested to [ContainerLogV2](container-insights-logs-schema.md) table. If not, the container logs are ingested to **ContainerLog** table, unless otherwise specified in the ConfigMap. When specifying the individual streams, you must include the corresponding table for ContainerLog or ContainerLogV2. | +| Collected Data<br>CLI: `streams`<br>ARM: `streams` | An array of container insights table streams. See the supported streams above to table mapping. | ++## Applicable tables and metrics +The settings for **collection frequency** and **namespace filtering** don't apply to all Container insights data. The following tables list the tables in the Log Analytics workspace used by Container insights and the metrics it collects along with the settings that apply to each. ++>[!NOTE] +>This feature configures settings for all container insights tables except for ContainerLog and ContainerLogV2. To configure settings for these tables, update the ConfigMap described in [agent data collection settings](../containers/container-insights-data-collection-configmap.md). +++| Table name | Interval? | Namespaces? | Remarks | +|:|::|::|:| +| ContainerInventory | Yes | Yes | | +| ContainerNodeInventory | Yes | No | Data collection setting for namespaces isn't applicable since Kubernetes Node isn't a namespace scoped resource | +| KubeNodeInventory | Yes | No | Data collection setting for namespaces isn't applicable Kubernetes Node isn't a namespace scoped resource | +| KubePodInventory | Yes | Yes || +| KubePVInventory | Yes | Yes | | +| KubeServices | Yes | Yes | | +| KubeEvents | No | Yes | Data collection setting for interval isn't applicable for the Kubernetes Events | +| Perf | Yes | Yes | Data collection setting for namespaces isn't applicable for the Kubernetes Node related metrics since the Kubernetes Node isn't a namespace scoped object. | +| InsightsMetrics| Yes | Yes | Data collection settings are only applicable for the metrics collecting the following namespaces: container.azm.ms/kubestate, container.azm.ms/pv and container.azm.ms/gpu | +++| Metric namespace | Interval? | Namespaces? | Remarks | +|:|::|::|:| +| Insights.container/nodes| Yes | No | Node isn't a namespace scoped resource | +|Insights.container/pods | Yes | Yes| | +| Insights.container/containers | Yes | Yes | | +| Insights.container/persistentvolumes | Yes | Yes | | ++++## Stream values +When you specify the tables to collect using CLI or ARM, you specify a stream name that corresponds to a particular table in the Log Analytics workspace. The following table lists the stream name for each table. ++> [!NOTE] +> If your familiar with the [structure of a data collection rule](../essentials/data-collection-rule-structure.md), the stream names in this table are specified in the [dataFlows](../essentials/data-collection-rule-structure.md#dataflows) section of the DCR. ++| Stream | Container insights table | +| | | +| Microsoft-ContainerInventory | ContainerInventory | +| Microsoft-ContainerLog | ContainerLog | +| Microsoft-ContainerLogV2 | ContainerLogV2 | +| Microsoft-ContainerNodeInventory | ContainerNodeInventory | +| Microsoft-InsightsMetrics | InsightsMetrics | +| Microsoft-KubeEvents | KubeEvents | +| Microsoft-KubeMonAgentEvents | KubeMonAgentEvents | +| Microsoft-KubeNodeInventory | KubeNodeInventory | +| Microsoft-KubePodInventory | KubePodInventory | +| Microsoft-KubePVInventory | KubePVInventory | +| Microsoft-KubeServices | KubeServices | +| Microsoft-Perf | Perf | +++## Impact on visualizations and alerts ++If you're currently using the above tables for other custom alerts or charts, then modifying your data collection settings might degrade those experiences. If you're excluding namespaces or reducing data collection frequency, review your existing alerts, dashboards, and workbooks using this data. ++To scan for alerts that reference these tables, run the following Azure Resource Graph query: ++```Kusto +resources +| where type in~ ('microsoft.insights/scheduledqueryrules') and ['kind'] !in~ ('LogToMetric') +| extend severity = strcat("Sev", properties["severity"]) +| extend enabled = tobool(properties["enabled"]) +| where enabled in~ ('true') +| where tolower(properties["targetResourceTypes"]) matches regex 'microsoft.operationalinsights/workspaces($|/.*)?' or tolower(properties["targetResourceType"]) matches regex 'microsoft.operationalinsights/workspaces($|/.*)?' or tolower(properties["scopes"]) matches regex 'providers/microsoft.operationalinsights/workspaces($|/.*)?' +| where properties contains "Perf" or properties contains "InsightsMetrics" or properties contains "ContainerInventory" or properties contains "ContainerNodeInventory" or properties contains "KubeNodeInventory" or properties contains"KubePodInventory" or properties contains "KubePVInventory" or properties contains "KubeServices" or properties contains "KubeEvents" +| project id,name,type,properties,enabled,severity,subscriptionId +| order by tolower(name) asc +``` ++++## Next steps ++- See [Configure data collection in Container insights using ConfigMap](container-insights-data-collection-configmap.md) to configure data collection using ConfigMap instead of the DCR. |
azure-monitor | Container Insights Enable Aks Policy | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-enable-aks-policy.md | - Title: Enable the AKS Monitoring Add-on by using Azure Policy -description: This article describes how to enable the AKS Monitoring Add-on by using a custom Azure policy. -- Previously updated : 08/29/2022----# Enable the AKS Monitoring Add-on by using Azure Policy -This article describes how to enable the Azure Kubernetes Service (AKS) Monitoring Add-on by using a custom Azure policy. --## Permissions required -The AKS Monitoring Add-on requires the following roles on the managed identity used by Azure Policy: ---The AKS Monitoring Add-on custom policy can be assigned at either the subscription or resource group scope. If the Log Analytics workspace and AKS cluster are in different subscriptions, the managed identity used by the policy assignment must have the required role permissions on both the subscriptions or on the Log Analytics workspace resource. Similarly, if the policy is scoped to the resource group, the managed identity should have the required role permissions on the Log Analytics workspace if the workspace isn't in the selected resource group scope. --## Create and assign a policy definition by using the Azure portal --Use the Azure portal to create and assign a policy definition. --### Create a policy definition --1. Download the Azure custom policy definition to enable the AKS Monitoring Add-on. -- ``` sh - curl -o azurepolicy.json -L https://aka.ms/aks-enable-monitoring-custom-policy - ``` --1. Go to the [Azure Policy Definitions](https://portal.azure.com/#blade/Microsoft_Azure_Policy/PolicyMenuBlade/Definitions) page. Create a policy definition with the following details on the **Policy definition** page: -- - **Definition location**: Select the Azure subscription where the policy definition should be stored. - - **Name**: *(Preview)AKS-Monitoring-Addon* - - **Description**: *Azure custom policy to enable the Monitoring Add-on onto Azure Kubernetes clusters in a specified scope* - - **Category**: Select **Use existing** and select **Kubernetes** from the dropdown list. - - **Policy rule**: Remove the existing sample rules and copy the contents of `azurepolicy.json` downloaded in step 1. --### Assign a policy definition to a specified scope --> [!NOTE] -> A managed identity will be created automatically and assigned specified roles in the policy definition. --1. Select the policy definition **(Preview) AKS Monitoring Addon** that you created. -1. Select **Assign** and specify a **Scope** of where the policy should be assigned. -1. Select **Next** and provide the resource ID of the Log Analytics workspace. The resource ID should be in the format `/subscriptions/<SubscriptionId>/resourceGroups/<ResourceGroup>/providers/Microsoft.OperationalInsights/workspaces/<workspaceName>`. -1. Create a remediation task if you want to apply the policy to existing AKS clusters in the selected scope. -1. Select **Review + create** to create the policy assignment. --## Create and assign a policy definition by using the Azure CLI --Use the Azure CLI to create and assign a policy definition. --### Create a policy definition --1. Download the Azure custom policy definition rules and parameter files with the following commands: -- ``` sh - curl -o azurepolicy.rules.json -L https://aka.ms/aks-enable-monitoring-custom-policy-rules - curl -o azurepolicy.parameters.json -L https://aka.ms/aks-enable-monitoring-custom-policy-parameters - ``` --1. Create the policy definition with the following command: -- ```azurecli - az cloud set -n <AzureCloud | AzureChinaCloud | AzureUSGovernment> # set the Azure cloud - az login # login to cloud environment - az account set -s <subscriptionId> - az policy definition create --name "(Preview)AKS-Monitoring-Addon" --display-name "(Preview)AKS-Monitoring-Addon" --mode Indexed --metadata version=1.0.0 category=Kubernetes --rules azurepolicy.rules.json --params azurepolicy.parameters.json - ``` --### Assign a policy definition to a specified scope --Create the policy assignment with the following command: --```azurecli -az policy assignment create --name aks-monitoring-addon --policy "(Preview)AKS-Monitoring-Addon" --assign-identity --identity-scope /subscriptions/<subscriptionId> --role Contributor --scope /subscriptions/<subscriptionId> --location <locatio> --role Contributor --scope /subscriptions/<subscriptionId> -p "{ \"workspaceResourceId\": { \"value\": \"/subscriptions/<subscriptionId>/resourcegroups/<resourceGroupName>/providers/microsoft.operationalinsights/workspaces/<workspaceName>\" } }" -``` --## Next steps --- Learn more about [Azure Policy](../../governance/policy/overview.md).-- Learn how [remediation access control works](../../governance/policy/how-to/remediate-resources.md#how-remediation-access-control-works).-- Learn more about [Container insights](./container-insights-overview.md).-- Install the [Azure CLI](/cli/azure/install-azure-cli). |
azure-monitor | Container Insights Enable Aks | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-enable-aks.md | - Title: Enable Container insights for Azure Kubernetes Service (AKS) cluster -description: Learn how to enable Container insights on an Azure Kubernetes Service (AKS) cluster. - Previously updated : 11/14/2023-----# Enable Container insights for Azure Kubernetes Service (AKS) cluster --This article describes how to enable Container insights on a managed Kubernetes cluster hosted on an [Azure Kubernetes Service (AKS)](../../aks/index.yml) cluster. --## Prerequisites --- See [Prerequisites](./container-insights-onboard.md) for Container insights.-- You can attach an AKS cluster to a Log Analytics workspace in a different Azure subscription in the same Microsoft Entra tenant, but you must use the Azure CLI or an Azure Resource Manager template. You can't currently perform this configuration with the Azure portal.-- If you're connecting an existing AKS cluster to a Log Analytics workspace in another subscription, the *Microsoft.ContainerService* resource provider must be registered in the subscription with the Log Analytics workspace. For more information, see [Register resource provider](../../azure-resource-manager/management/resource-providers-and-types.md#register-resource-provider).---## Enable monitoring --### [Azure portal](#tab/azure-portal) --There are multiple options to enable Prometheus metrics on your cluster from the Azure portal. ---### New cluster -When you create a new AKS cluster in the Azure portal, you can enable Prometheus, Container insights, and Grafana from the **Integrations** tab. In the Azure Monitor section, select either **Default configuration** or **Custom configuration** if you want to specify which workspaces to use. You can perform additional configuration once the cluster is created. ---### From existing cluster --This option enables Container insights on a cluster and gives you the option of also enabling [Managed Prometheus and Managed Grafana](./prometheus-metrics-enable.md) for the cluster. --> [!NOTE] -> If you want to enabled Managed Prometheus without Container insights, then [enable it from the Azure Monitor workspace](./prometheus-metrics-enable.md). --1. Open the cluster's menu in the Azure portal and select **Insights**. - 1. If Container insights isn't enabled for the cluster, then you're presented with a screen identifying which of the features have been enabled. Click **Configure monitoring**. -- :::image type="content" source="media/aks-onboard/configure-monitoring-screen.png" lightbox="media/aks-onboard/configure-monitoring-screen.png" alt-text="Screenshot that shows the configuration screen for a cluster."::: -- 2. If Container insights has already been enabled on the cluster, select the **Monitoring Settings** button to modify the configuration. -- :::image type="content" source="media/aks-onboard/monitor-settings-button.png" lightbox="media/aks-onboard/monitor-settings-button.png" alt-text="Screenshot that shows the monitoring settings button for a cluster."::: --2. The **Container insights** will be enabled. **Select** the checkboxes for **Enable Prometheus metrics** and **Enable Grafana** if you also want to enable them for the cluster. If you have existing Azure Monitor workspace and Grafana workspace, then they're selected for you. -- :::image type="content" source="media/prometheus-metrics-enable/configure-container-insights.png" lightbox="media/prometheus-metrics-enable/configure-container-insights.png" alt-text="Screenshot that shows the dialog box to configure Container insights with Prometheus and Grafana."::: --3. Click **Advanced settings** to select alternate workspaces or create new ones. The **Cost presets** setting allows you to modify the default collection details to reduce your monitoring costs. See [Enable cost optimization settings in Container insights](./container-insights-cost-config.md) for details. -- :::image type="content" source="media/aks-onboard/advanced-settings.png" lightbox="media/aks-onboard/advanced-settings.png" alt-text="Screenshot that shows the advanced settings dialog box."::: --4. Click **Configure** to save the configuration. --### From Container insights -From the Container insights menu, you can view all of your clusters, quickly identify which aren't monitored, and launch the same configuration experience as described in [From existing cluster](#from-existing-cluster). --1. Open the **Monitor** menu in the Azure portal and select **Insights**. -3. The **Unmonitored clusters** tab lists clusters that don't have Container insights enabled. Click **Enable** next to a cluster and follow the guidance in [Existing cluster](#existing-cluster). ---## [CLI](#tab/azure-cli) --> [!NOTE] -> Managed identity authentication will be default in CLI version 2.49.0 or higher. If you need to use legacy/non-managed identity authentication, use CLI version < 2.49.0. For CLI version 2.54.0 or higher the logging schema will be configured to [ContainerLogV2](container-insights-logging-v2.md) via the ConfigMap --### Use a default Log Analytics workspace --Use the following command to enable monitoring of your AKS cluster by using a default Log Analytics workspace for the resource group. If a default workspace doesn't already exist in the cluster's region, one will be created with a name in the format *DefaultWorkspace-\<GUID>-\<Region>*. --```azurecli -az aks enable-addons -a monitoring -n <cluster-name> -g <cluster-resource-group-name> -``` --The output will resemble the following example: --```output -provisioningState : Succeeded -``` --### Specify a Log Analytics workspace --Use the following command to enable monitoring of your AKS cluster on a specific Log Analytics workspace. The resource ID of the workspace will be in the form `"/subscriptions/<SubscriptionId>/resourceGroups/<ResourceGroupName>/providers/Microsoft.OperationalInsights/workspaces/<WorkspaceName>"`. --```azurecli -az aks enable-addons -a monitoring -n <cluster-name> -g <cluster-resource-group-name> --workspace-resource-id <workspace-resource-id> -``` --**Example** --```azurecli -az aks enable-addons -a monitoring -n <cluster-name> -g <cluster-resource-group-name> --workspace-resource-id "/subscriptions/my-subscription/resourceGroups/my-resource-group/providers/Microsoft.OperationalInsights/workspaces/my-workspace" -``` ---## [Resource Manager template](#tab/arm) -->[!NOTE] ->The template must be deployed in the same resource group as the cluster. --1. Download the template and parameter file. - - Template file: [https://aka.ms/aks-enable-monitoring-msi-onboarding-template-file](https://aka.ms/aks-enable-monitoring-msi-onboarding-template-file) - - Parameter file: [https://aka.ms/aks-enable-monitoring-msi-onboarding-template-parameter-file](https://aka.ms/aks-enable-monitoring-msi-onboarding-template-parameter-file) --2. Edit the following values in the parameter file: -- | Parameter | Description | - |:|:| - | `aksResourceId` | Use the values on the **AKS Overview** page for the AKS cluster. | - | `aksResourceLocation` | Use the values on the **AKS Overview** page for the AKS cluster. | - | `workspaceResourceId` | Use the resource ID of your Log Analytics workspace. | - | `resourceTagValues` | Match the existing tag values specified for the existing Container insights extension data collection rule (DCR) of the cluster and the name of the DCR. The name will be *MSCI-\<clusterName\>-\<clusterRegion\>* and this resource created in an AKS clusters resource group. If this is the first time onboarding, you can set the arbitrary tag values. | --3. Deploy the template with the parameter file by using any valid method for deploying Resource Manager templates. For examples of different methods, see [Deploy the sample templates](../resource-manager-samples.md#deploy-the-sample-templates). --## [Bicep](#tab/bicep) --### Existing cluster --1. Download Bicep templates and parameter files depending on whether you want to enable Syslog collection. -- **Syslog** - - Template file: [Template with Syslog](https://aka.ms/enable-monitoring-msi-syslog-bicep-template) - - Parameter file: [Parameter with Syslog](https://aka.ms/enable-monitoring-msi-syslog-bicep-parameters) -- **No Syslog** - - Template file: [Template without Syslog](https://aka.ms/enable-monitoring-msi-bicep-template) - - Parameter file: [Parameter without Syslog](https://aka.ms/enable-monitoring-msi-bicep-parameters) --2. Edit the following values in the parameter file: - - | Parameter | Description | - |:|:| - | `aksResourceId` | Use the values on the AKS Overview page for the AKS cluster. | - | `aksResourceLocation` | Use the values on the AKS Overview page for the AKS cluster. | - | `workspaceResourceId` | Use the resource ID of your Log Analytics workspace. | - | `workspaceRegion` | Use the location of your Log Analytics workspace. | - | `resourceTagValues` | Match the existing tag values specified for the existing Container insights extension data collection rule (DCR) of the cluster and the name of the DCR. The name will match `MSCI-<clusterName>-<clusterRegion>` and this resource is created in the same resource group as the AKS clusters. For first time onboarding, you can set the arbitrary tag values. | - | `enabledContainerLogV2` | Set this parameter value to be true to use the default recommended ContainerLogV2 schema - | Cost optimization parameters | Refer to [Data collection parameters](container-insights-cost-config.md#data-collection-parameters) | --3. Deploy the template with the parameter file by using any valid method for deploying Resource Manager templates. For examples of different methods, see [Deploy the sample templates](../resource-manager-samples.md#deploy-the-sample-templates). ---### New cluster -Replace and use the managed cluster resources in [Deploy an Azure Kubernetes Service (AKS) cluster using Bicep](../../aks/learn/quick-kubernetes-deploy-bicep.md). ----## [Terraform](#tab/terraform) --### New AKS cluster --1. Download Terraform template file depending on whether you want to enable Syslog collection. -- **Syslog** - - [https://aka.ms/enable-monitoring-msi-syslog-terraform](https://aka.ms/enable-monitoring-msi-syslog-terraform) -- **No Syslog** - - [https://aka.ms/enable-monitoring-msi-terraform](https://aka.ms/enable-monitoring-msi-terraform) --2. Adjust the `azurerm_kubernetes_cluster` resource in *main.tf* based on what cluster settings you're going to have. -3. Update parameters in *variables.tf* to replace values in "<>" -- | Parameter | Description | - |:|:| - | `aks_resource_group_name` | Use the values on the AKS Overview page for the resource group. | - | `resource_group_location` | Use the values on the AKS Overview page for the resource group. | - | `cluster_name` | Define the cluster name that you would like to create. | - | `workspace_resource_id` | Use the resource ID of your Log Analytics workspace. | - | `workspace_region` | Use the location of your Log Analytics workspace. | - | `resource_tag_values` | Match the existing tag values specified for the existing Container insights extension data collection rule (DCR) of the cluster and the name of the DCR. The name will match `MSCI-<clusterName>-<clusterRegion>` and this resource is created in the same resource group as the AKS clusters. For first time onboarding, you can set the arbitrary tag values. | - | `enabledContainerLogV2` | Set this parameter value to be true to use the default recommended ContainerLogV2. | - | Cost optimization parameters | Refer to [Data collection parameters](container-insights-cost-config.md#data-collection-parameters) | ---4. Run `terraform init -upgrade` to initialize the Terraform deployment. -5. Run `terraform plan -out main.tfplan` to initialize the Terraform deployment. -6. Run `terraform apply main.tfplan` to apply the execution plan to your cloud infrastructure. ---### Existing AKS cluster -1. Import the existing cluster resource first with the command: ` terraform import azurerm_kubernetes_cluster.k8s <aksResourceId>` -2. Add the oms_agent add-on profile to the existing azurerm_kubernetes_cluster resource. - ``` - oms_agent { - log_analytics_workspace_id = var.workspace_resource_id - msi_auth_for_monitoring_enabled = true - } - ``` -3. Copy the DCR and DCRA resources from the Terraform templates -4. Run `terraform plan -out main.tfplan` and make sure the change is adding the oms_agent property. Note: If the `azurerm_kubernetes_cluster` resource defined is different during terraform plan, the existing cluster will get destroyed and recreated. -5. Run `terraform apply main.tfplan` to apply the execution plan to your cloud infrastructure. --> [!TIP] -> - Edit the `main.tf` file appropriately before running the terraform template -> - Data will start flowing after 10 minutes since the cluster needs to be ready first -> - WorkspaceID needs to match the format `/subscriptions/12345678-1234-9876-4563-123456789012/resourceGroups/example-resource-group/providers/Microsoft.OperationalInsights/workspaces/workspaceValue` -> - If resource group already exists, run `terraform import azurerm_resource_group.rg /subscriptions/<Subscription_ID>/resourceGroups/<Resource_Group_Name>` before terraform plan --### [Azure Policy](#tab/policy) --1. Download Azure Policy template and parameter files depending on whether you want to enable Syslog collection. -- - Template file: [https://aka.ms/enable-monitoring-msi-azure-policy-template](https://aka.ms/enable-monitoring-msi-azure-policy-template) - - Parameter file: [https://aka.ms/enable-monitoring-msi-azure-policy-parameters](https://aka.ms/enable-monitoring-msi-azure-policy-parameters) --2. Create the policy definition using the following command: -- ``` - az policy definition create --name "AKS-Monitoring-Addon-MSI" --display-name "AKS-Monitoring-Addon-MSI" --mode Indexed --metadata version=1.0.0 category=Kubernetes --rules azure-policy.rules.json --params azure-policy.parameters.json - ``` --3. Create the policy assignment using the following CLI command or any [other available method](../../governance/policy/assign-policy-portal.md). -- ``` - az policy assignment create --name aks-monitoring-addon --policy "AKS-Monitoring-Addon-MSI" --assign-identity --identity-scope /subscriptions/<subscriptionId> --role Contributor --scope /subscriptions/<subscriptionId> --location <location> --role Contributor --scope /subscriptions/<subscriptionId> -p "{ \"workspaceResourceId\": { \"value\": \"/subscriptions/<subscriptionId>/resourcegroups/<resourceGroupName>/providers/microsoft.operationalinsights/workspaces/<workspaceName>\" } }" - ``` --> [!TIP] -> - Make sure when performing remediation task, the policy assignment has access to workspace you specified. -> - Download all files under *AddonPolicyTemplate* folder before running the policy template. ----## Verify agent and solution deployment -You can verify that the agent is deployed properly using the [kubectl command line tool](../../aks/learn/quick-kubernetes-deploy-cli.md#connect-to-the-cluster). --``` -kubectl get ds ama-logs --namespace=kube-system -``` --The output should resemble the following example, which indicates that it was deployed properly: --```output -User@aksuser:~$ kubectl get ds ama-logs --namespace=kube-system -NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE -ama-logs 2 2 2 2 2 beta.kubernetes.io/os=linux 1d -``` --If there are Windows Server nodes on the cluster, run the following command to verify that the agent is deployed successfully: --``` -kubectl get ds ama-logs-windows --namespace=kube-system -``` --The output should resemble the following example, which indicates that it was deployed properly: --```output -User@aksuser:~$ kubectl get ds ama-logs-windows --namespace=kube-system -NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE -ama-logs-windows 2 2 2 2 2 beta.kubernetes.io/os=windows 1d -``` --To verify deployment of the solution, run the following command: --``` -kubectl get deployment ama-logs-rs -n=kube-system -``` --The output should resemble the following example, which indicates that it was deployed properly: --```output -User@aksuser:~$ kubectl get deployment ama-logs-rs -n=kube-system -NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE -ama-logs-rs 1 1 1 1 3h -``` --## View configuration with CLI --Use the `aks show` command to find out whether the solution is enabled or not, what the Log Analytics workspace resource ID is, and summary information about the cluster. --```azurecli -az aks show -g <resourceGroupofAKSCluster> -n <nameofAksCluster> -``` --The command will return JSON-formatted information about the solution. The `addonProfiles` section should include information on the `omsagent` as in the following example: --```output -"addonProfiles": { - "omsagent": { - "config": { - "logAnalyticsWorkspaceResourceID": "/subscriptions/<WorkspaceSubscription>/resourceGroups/<DefaultWorkspaceRG>/providers/Microsoft.OperationalInsights/workspaces/<defaultWorkspaceName>" - }, - "enabled": true - } - } -``` ----## Limitations --- Dependency on DCR/DCRA for region availability. For new AKS region, there might be chances that DCR is still not supported in the new region. In that case, onboarding Container Insights with MSI will fail. One workaround is to onboard to Container Insights through CLI with the old way (with the use of Container Insights solution)-- You must be on a machine on the same private network to access live logs from a private cluster.--## Next steps --* If you experience issues while you attempt to onboard the solution, review the [Troubleshooting guide](container-insights-troubleshoot.md). -* With monitoring enabled to collect health and resource utilization of your AKS cluster and workloads running on them, learn [how to use](container-insights-analyze.md) Container insights. |
azure-monitor | Container Insights Enable Arc Enabled Clusters | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-enable-arc-enabled-clusters.md | - Title: Monitor Azure Arc-enabled Kubernetes clusters Previously updated : 08/02/2023-- -description: Collect metrics and logs of Azure Arc-enabled Kubernetes clusters using Azure Monitor. ----# Azure Monitor Container Insights for Azure Arc-enabled Kubernetes clusters --[Azure Monitor Container Insights](container-insights-overview.md) provides rich monitoring experience for Azure Arc-enabled Kubernetes clusters. ---## Supported configurations --- Azure Monitor Container Insights supports monitoring Azure Arc-enabled Kubernetes as described in the [Overview](container-insights-overview.md) article, except the live data feature. Also, users aren't required to have [Owner](../../role-based-access-control/built-in-roles.md#owner) permissions to [enable metrics](container-insights-update-metrics.md)-- `Docker`, `Moby`, and CRI compatible container runtimes such `CRI-O` and `containerd`.-- Outbound proxy without authentication and outbound proxy with basic authentication are supported. Outbound proxy that expects trusted certificates is currently not supported.-->[!NOTE] ->If you are migrating from Container Insights on Azure Red Hat OpenShift v4.x, please also ensure that you have [disabled monitoring](./container-insights-optout-hybrid.md) before proceeding with configuring Container Insights on Azure Arc enabled Kubernetes to prevent any installation issues. -> ---## Prerequisites --- Pre-requisites listed under the [generic cluster extensions documentation](../../azure-arc/kubernetes/extensions.md#prerequisites).-- Log Analytics workspace. Azure Monitor Container Insights supports a Log Analytics workspace in the regions listed under Azure [products by region page](https://azure.microsoft.com/global-infrastructure/services/?regions=all&products=monitor). You can create your own workspace using [Azure Resource Manager](../logs/resource-manager-workspace.md), [PowerShell](../logs/powershell-workspace-configuration.md), or [Azure portal](../logs/quick-create-workspace.md).-- [Contributor](../../role-based-access-control/built-in-roles.md#contributor) role assignment on the Azure subscription containing the Azure Arc-enabled Kubernetes resource. If the Log Analytics workspace is in a different subscription, then [Log Analytics Contributor](../logs/manage-access.md#azure-rbac) role assignment is needed on the resource group containing the Log Analytics Workspace-- To view the monitoring data, you need to have [Monitoring Reader](../roles-permissions-security.md#monitoring-reader) or [Monitoring Contributor](../roles-permissions-security.md#monitoring-contributor) role.-- Verify the [firewall requirements for Container insights](./container-insights-onboard.md#network-firewall-requirements) in addition to the [Azure Arc-enabled Kubernetes network requirements](../../azure-arc/kubernetes/network-requirements.md).-- If you are using an Arc enabled cluster on AKS, and previously installed [monitoring for AKS](./container-insights-enable-existing-clusters.md), please ensure that you have [disabled monitoring](./container-insights-optout.md) before proceeding to avoid issues during the extension install.-- If you had previously deployed Azure Monitor Container Insights on this cluster using script without cluster extensions, follow the instructions listed [here](container-insights-optout-hybrid.md) to delete this Helm chart. You can then continue to creating a cluster extension instance for Azure Monitor Container Insights.---### Identify workspace resource ID --Run the following commands to locate the full Azure Resource Manager identifier of the Log Analytics workspace. --1. List all the subscriptions that you have access to using the following command: -- ```azurecli - az account list --all -o table - ``` --2. Switch to the subscription hosting the Log Analytics workspace using the following command: -- ```azurecli - az account set -s <subscriptionId of the workspace> - ``` --3. The following example displays the list of workspaces in your subscriptions in the default JSON format. -- ```azurecli - az resource list --resource-type Microsoft.OperationalInsights/workspaces -o json - ``` -- In the output, find the workspace name of interest. The `id` field of that represents the Azure Resource Manager identifier of that Log Analytics workspace. -- >[!TIP] - > This `id` can also be found in the *Overview* pane of the Log Analytics workspace through the Azure portal. --## Create extension instance --## [CLI](#tab/create-cli) --### Option 1 - With default values --This option uses the following defaults: --- Creates or uses existing default log analytics workspace corresponding to the region of the cluster-- Auto-upgrade is enabled for the Azure Monitor cluster extension-->[!NOTE] -> Managed identity authentication is the default in k8s-extension version 1.43.0 or higher. --```azurecli -az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers -``` --To use [managed identity authentication](container-insights-onboard.md#authentication), add the `configuration-settings` parameter as in the following: --```azurecli -az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.useAADAuth=true -``` -->[!NOTE] -> Managed identity authentication is not supported for Arc-enabled Kubernetes clusters with ARO (Azure Red Hat Openshift) or Windows nodes. -> --To use legacy/non-managed identity authentication to create an extension instance on **Arc K8S connected clusters with ARO**, use the commands below that don't use managed identity. Non-cli onboarding is not supported for Arc-enabled Kubernetes clusters with **ARO**. --Install the extension with **amalogs.useAADAuth=false**. --```azurecli -az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.useAADAuth=false -``` --### Option 2 - With existing Azure Log Analytics workspace --You can use an existing Azure Log Analytics workspace in any subscription on which you have *Contributor* or a more permissive role assignment. --```azurecli -az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings logAnalyticsWorkspaceResourceID=<armResourceIdOfExistingWorkspace> -``` --### Option 3 - With advanced configuration --If you want to tweak the default resource requests and limits, you can use the advanced configurations settings: --```azurecli -az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.resources.daemonset.limits.cpu=150m amalogs.resources.daemonset.limits.memory=600Mi amalogs.resources.deployment.limits.cpu=1 amalogs.resources.deployment.limits.memory=750Mi -``` --Check out the [resource requests and limits section of Helm chart](https://github.com/microsoft/Docker-Provider/blob/ci_prod/charts/azuremonitor-containers/values.yaml) for the available configuration settings. --### Option 4 - On Azure Stack Edge --If the Azure Arc-enabled Kubernetes cluster is on Azure Stack Edge, then a custom mount path `/home/data/docker` needs to be used. --```azurecli -az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.logsettings.custommountpath=/home/data/docker -``` --### Option 5 - With Azure Monitor Private Link Scope (AMPLS) + Proxy --If the cluster is configured with a forward proxy, then proxy settings are automatically applied to the extension. In the case of a cluster with AMPLS + proxy, proxy config should be ignored. Onboard the extension with the configuration setting `amalogs.ignoreExtensionProxySettings=true`. --```azurecli -az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.ignoreExtensionProxySettings=true -``` -->[!NOTE] -> If you are explicitly specifying the version of the extension to be installed in the create command, then ensure that the version specified is >= 2.8.2. --## [Azure portal](#tab/create-portal) -->[!IMPORTANT] -> If you are deploying Azure Monitor on a Kubernetes cluster running on top of Azure Stack Edge, then the Azure CLI option needs to be followed instead of the Azure portal option as a custom mount path needs to be set for these clusters. --### Onboarding from the Azure Arc-enabled Kubernetes resource pane --1. In the Azure portal, select the Azure Arc-enabled Kubernetes cluster that you wish to monitor. --2. From the resource pane on the left, select the 'Insights' item under the 'Monitoring' section. --3. On the onboarding page, select the 'Configure Azure Monitor' button --4. You can now choose the [Log Analytics workspace](../logs/quick-create-workspace.md) to send your metrics and logs data to. --5. To use managed identity authentication, select the *Use managed identity* checkbox. --6. Select the 'Configure' button to deploy the Azure Monitor Container Insights cluster extension. --### Onboarding from Azure Monitor pane --1. In the Azure portal, navigate to the 'Monitor' pane, and select the 'Containers' option under the 'Insights' menu. --2. Select the 'Unmonitored clusters' tab to view the Azure Arc-enabled Kubernetes clusters that you can enable monitoring for. --3. Click on the 'Enable' link next to the cluster that you want to enable monitoring for. --4. Choose the Log Analytics workspace. --5. To use managed identity authentication, select the *Use managed identity* checkbox. --6. Select the 'Configure' button to continue. --## [ARM](#tab/create-arm) --This sections has instructions for onboarding with legacy authentication. For MSI based onboarding, see next tab. --1. Download Azure Resource Manager template and parameter: -- ```console - curl -L https://aka.ms/arc-k8s-azmon-extension-arm-template -o arc-k8s-azmon-extension-arm-template.json - curl -L https://aka.ms/arc-k8s-azmon-extension-arm-template-params -o arc-k8s-azmon-extension-arm-template-params.json - ``` --2. Update parameter values in arc-k8s-azmon-extension-arm-template-params.json file. For Azure public cloud, `opinsights.azure.com` needs to be used as the value of workspaceDomain and for AzureUSGovernment, `opinsights.azure.us` needs to be used as the value of workspaceDomain. --3. Deploy the template to create Azure Monitor Container Insights extension -- ```azurecli - az login - az account set --subscription "Subscription Name" - az deployment group create --resource-group <resource-group> --template-file ./arc-k8s-azmon-extension-arm-template.json --parameters @./arc-k8s-azmon-extension-arm-template-params.json - ``` --## [ARM (with MSI)](#tab/create-arm-msi) --Onboard using an ARM template with MSI based authentication enabled --1. Download Azure Resource Manager template and parameter: -- ```console - curl -L https://aka.ms/arc-k8s-azmon-extension-msi-arm-template -o arc-k8s-azmon-extension-arm-template.json - curl -L https://aka.ms/arc-k8s-azmon-extension-msi-arm-template-params -o arc-k8s-azmon-extension-arm-template-params.json - ``` --2. Update parameter values in arc-k8s-azmon-extension-arm-template-params.json file. For Azure public cloud, `opinsights.azure.com` needs to be used as the value of workspaceDomain and for AzureUSGovernment, `opinsights.azure.us` needs to be used as the value of workspaceDomain. --3. Deploy the template to create Azure Monitor Container Insights extension -- ```azurecli - az login - az account set --subscription "Subscription Name" - az deployment group create --resource-group <resource-group> --template-file ./arc-k8s-azmon-extension-arm-template.json --parameters @./arc-k8s-azmon-extension-arm-template-params.json - ``` ----## Verify extension installation status -Once you have successfully created the Azure Monitor extension for your Azure Arc-enabled Kubernetes cluster, you can additionally check the status of installation using the Azure portal or CLI. Successful installations should show the status as 'Installed'. If your status is showing 'Failed' or remains in the 'Pending' state for long periods of time, proceed to the Troubleshooting section below. --### [Azure portal](#tab/verify-portal) -1. In the Azure portal, select the Azure Arc-enabled Kubernetes cluster with the extension installing -2. From the resource pane on the left, select the 'Extensions' item under the 'Settings' section. -3. You should see an extension with the name 'azuremonitor-containers' listed, with the listed status in the 'Install status' column -### [CLI](#tab/verify-cli) -Run the following command to show the latest status of the `Microsoft.AzureMonitor.Containers` extension -```azurecli -az k8s-extension show --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters -n azuremonitor-containers -``` -----## Delete extension instance --The following command only deletes the extension instance, but doesn't delete the Log Analytics workspace. The data within the Log Analytics resource is left intact. --```azurecli -az k8s-extension delete --name azuremonitor-containers --cluster-type connectedClusters --cluster-name <cluster-name> --resource-group <resource-group> -``` --## Disconnected cluster -If your cluster is disconnected from Azure for > 48 hours, then Azure Resource Graph won't have information about your cluster. As a result the Insights pane may display incorrect information about your cluster state. --## Troubleshooting -For issues with enabling monitoring, we have provided a [troubleshooting script](https://aka.ms/azmon-ci-troubleshooting) to help diagnose any problems. --## Next steps --- With monitoring enabled to collect health and resource utilization of your Azure Arc-enabled Kubernetes cluster and workloads running on them, learn [how to use](container-insights-analyze.md) Container insights.--- By default, the containerized agent collects the stdout/ stderr container logs of all the containers running in all the namespaces except kube-system. To configure container log collection specific to particular namespace or namespaces, review [Container Insights agent configuration](container-insights-agent-config.md) to configure desired data collection settings to your ConfigMap configurations file.--- To scrape and analyze Prometheus metrics from your cluster, review [Configure Prometheus metrics scraping](container-insights-prometheus-integration.md) |
azure-monitor | Container Insights Enable Provisioned Clusters | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-enable-provisioned-clusters.md | - Title: Monitor AKS hybrid clusters Previously updated : 01/10/2023- -description: Collect metrics and logs of AKS hybrid clusters using Azure Monitor. ----# Azure Monitor container insights for Azure Kubernetes Service (AKS) hybrid clusters (preview) -->[!NOTE] ->Support for monitoring AKS hybrid clusters is currently in preview. We recommend only using preview features in safe testing environments. --[Azure Monitor container insights](./container-insights-overview.md) provides a rich monitoring experience for [AKS hybrid clusters (preview)](/azure/aks/hybrid/aks-hybrid-options-overview). This article describes how to set up Container insights to monitor an AKS hybrid cluster. --## Supported configurations --- Azure Monitor container insights supports monitoring only Linux containers.--## Prerequisites --- Pre-requisites listed under the [generic cluster extensions documentation](../../azure-arc/kubernetes/extensions.md#prerequisites).-- Log Analytics workspace. Azure Monitor Container Insights supports a Log Analytics workspace in the regions listed under Azure [products by region page](https://azure.microsoft.com/global-infrastructure/services/?regions=all&products=monitor). You can create your own workspace using [Azure Resource Manager](../logs/resource-manager-workspace.md), [PowerShell](../logs/powershell-workspace-configuration.md), or [Azure portal](../logs/quick-create-workspace.md).-- [Contributor](../../role-based-access-control/built-in-roles.md#contributor) role assignment on the Azure subscription containing the Azure Arc-enabled Kubernetes resource. If the Log Analytics workspace is in a different subscription, then [Log Analytics Contributor](../logs/manage-access.md#azure-rbac) role assignment is needed on the Log Analytics workspace.-- To view the monitoring data, you need to have [Log Analytics Reader](../logs/manage-access.md#azure-rbac) role assignment on the Log Analytics workspace.-- The following endpoints need to be enabled for outbound access in addition to the [Azure Arc-enabled Kubernetes network requirements](../../azure-arc/kubernetes/network-requirements.md).-- Azure CLI version 2.43.0 or higher-- Azure k8s-extension version 1.3.7 or higher-- Azure Resource-graph version 2.1.0--## Onboarding --## [CLI](#tab/create-cli) --```acli -az login --az account set --subscription <cluster-subscription-name> --az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type provisionedclusters --cluster-resource-provider "microsoft.hybridcontainerservice" --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.useAADAuth=true -``` -## [Azure portal](#tab/create-portal) --### Onboarding from the AKS hybrid resource pane --1. In the Azure portal, select the AKS hybrid cluster that you wish to monitor. --2. From the resource pane on the left, select the 'Insights' item under the 'Monitoring' section. --3. On the onboarding page, select the 'Configure Azure Monitor' button --4. You can now choose the [Log Analytics workspace](../logs/quick-create-workspace.md) to send your metrics and logs data to. --5. Select the 'Configure' button to deploy the Azure Monitor Container Insights cluster extension. --### Onboarding from Azure Monitor pane --1. In the Azure portal, navigate to the 'Monitor' pane, and select the 'Containers' option under the 'Insights' menu. --2. Select the 'Unmonitored clusters' tab to view the AKS hybrid clusters that you can enable monitoring for. --3. Click on the 'Enable' link next to the cluster that you want to enable monitoring for. --4. Choose the Log Analytics workspace. --5. Select the 'Configure' button to continue. ---## [Resource Manager](#tab/create-arm) --1. Download the Azure Resource Manager Template and Parameter files --```bash -curl -L https://aka.ms/existingClusterOnboarding.json -o existingClusterOnboarding.json -``` --```bash -curl -L https://aka.ms/existingClusterParam.json -o existingClusterParam.json -``` --2. Edit the values in the parameter file. -- - For clusterResourceId and clusterRegion, use the values on the Overview page for the LCM cluster - - For workspaceResourceId, use the resource ID of your Log Analytics workspace - - For workspaceRegion, use the Location of your Log Analytics workspace - - For workspaceDomain, use the workspace domain value as ΓÇ£opinsights.azure.comΓÇ¥ for public cloud and for Microsoft Azure operated by 21Vianet cloud as ΓÇ£opinsights.azure.cnΓÇ¥ - - For resourceTagValues, leave as empty if not specific --3. Deploy the ARM template --```azurecli -az login --az account set --subscription <cluster-subscription-name> --az deployment group create --resource-group <resource-group> --template-file ./existingClusterOnboarding.json --parameters existingClusterParam.json -``` ---## Validation --### Extension details --Showing the extension details: --```azcli -az k8s-extension list --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type provisionedclusters --cluster-resource-provider "microsoft.hybridcontainerservice" -``` ---## Delete extension --The command for deleting the extension: --```azcli -az k8s-extension delete --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type provisionedclusters --cluster-resource-provider "microsoft.hybridcontainerservice" --name azuremonitor-containers --yes -``` --## Known Issues/Limitations --- Windows containers are not supported currently |
azure-monitor | Container Insights Hybrid Setup | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-hybrid-setup.md | Supported API definitions for the Azure Stack Hub cluster can be found in the ex ## Configure agent data collection -Starting with chart version 1.0.0, the agent data collection settings are controlled from the ConfigMap. For more information on agent data collection settings, see [Configure agent data collection for Container insights](container-insights-agent-config.md). +Starting with chart version 1.0.0, the agent data collection settings are controlled from the ConfigMap. For more information on agent data collection settings, see [Configure agent data collection for Container insights](container-insights-data-collection-configmap.md). After you've successfully deployed the chart, you can review the data for your hybrid Kubernetes cluster in Container insights from the Azure portal. |
azure-monitor | Container Insights Livedata Overview | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-livedata-overview.md | For help with setting up or troubleshooting the Live Data feature, see the [Setu ## View AKS resource live logs +> [!NOTE] +> You must be on a machine on the same private network to access live logs from a private cluster. + To view the live logs for pods, deployments, replica sets, stateful sets, daemon sets, and jobs with or without Container insights from the AKS resource view: 1. In the Azure portal, browse to the AKS cluster resource group and select your AKS resource. |
azure-monitor | Container Insights Log Query | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-log-query.md | ContainerInventory ### Kubernetes events > [!NOTE]-> By default, Normal event types aren't collected, so you won't see them when you query the KubeEvents table unless the *collect_all_kube_events* ConfigMap setting is enabled. If you need to collect Normal events, enable *collect_all_kube_events setting* in the *container-azm-ms-agentconfig* ConfigMap. See [Configure agent data collection for Container insights](./container-insights-agent-config.md) for information on how to configure the ConfigMap. +> By default, Normal event types aren't collected, so you won't see them when you query the KubeEvents table unless the *collect_all_kube_events* ConfigMap setting is enabled. If you need to collect Normal events, enable *collect_all_kube_events setting* in the *container-azm-ms-agentconfig* ConfigMap. See [Configure agent data collection for Container insights](./container-insights-data-collection-configmap.md) for information on how to configure the ConfigMap. ``` kusto KubePodInventory ## Container logs -Container logs for AKS are stored in [the ContainerLogV2 table](./container-insights-logging-v2.md). You can run the following sample queries to look for the stderr/stdout log output from target pods, deployments, or namespaces. +Container logs for AKS are stored in [the ContainerLogV2 table](./container-insights-logs-schema.md). You can run the following sample queries to look for the stderr/stdout log output from target pods, deployments, or namespaces. ### Container logs for a specific pod, namespace, and container |
azure-monitor | Container Insights Logging V2 | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-logging-v2.md | - Title: Configure the ContainerLogV2 schema for Container Insights -description: Switch your ContainerLog table to the ContainerLogV2 schema. ----- Previously updated : 08/28/2023----# Enable the ContainerLogV2 schema -Azure Monitor Container insights offers a schema for container logs, called ContainerLogV2. As part of this schema, there are fields to make common queries to view Azure Kubernetes Service (AKS) and Azure Arc-enabled Kubernetes data. In addition, this schema is compatible with [Basic Logs](../logs/basic-logs-configure.md), which offers a low-cost alternative to standard analytics logs. -->[!NOTE] -> ContainerLogV2 will be the default schema via the ConfigMap for CLI version 2.54.0 and greater. ContainerLogV2 will be default ingestion format for customers who will be onboarding container insights with Managed Identity Auth using ARM, Bicep, Terraform, Policy and Portal onboarding. ContainerLogV2 can be explicitly enabled through CLI version 2.51.0 or higher using Data collection settings. --The new fields are: -* `ContainerName` -* `PodName` -* `PodNamespace` --## ContainerLogV2 schema -```kusto - Computer: string, - ContainerId: string, - ContainerName: string, - PodName: string, - PodNamespace: string, - LogMessage: dynamic, - LogSource: string, - TimeGenerated: datetime -``` -->[!NOTE] -> [Export](../logs/logs-data-export.md) to Event Hub and Storage Account is not supported if the incoming LogMessage is not a valid JSON. For best performance, we recommend emitting container logs in JSON format. --## Enable the ContainerLogV2 schema -Customers can enable the ContainerLogV2 schema at the cluster level through either the cluster's Data Collection Rule (DCR) or ConfigMap. To enable the ContainerLogV2 schema, configure the cluster's ConfigMap. Learn more about ConfigMap in [Kubernetes documentation](https://kubernetes.io/docs/tasks/configure-pod-container/configure-pod-configmap/) and in [Azure Monitor documentation](./container-insights-agent-config.md#configmap-file-settings-overview). -Follow the instructions to configure an existing ConfigMap or to use a new one. -->[!NOTE] -> Because ContainerLogV2 can be enabled through either the DCR and ConfigMap, when both are enabled the ContainerLogV2 setting of the ConfigMap will take precedence. Stdout and stderr logs will only be ingested to the ContainerLog table when both the DCR and ConfigMap are explicitly set to off. --### Configure via an existing Data Collection Rule (DCR) --## [Azure portal](#tab/configure-portal) -->[!NOTE] -> DCR based configuration is not supported for service principal based clusters. Please [migrate your clusters with service principal to managed identity](./container-insights-authentication.md) to use this experience. --1. In the Insights section of your Kubernetes cluster, select the **Monitoring Settings** button from the top toolbar ---2. Select **Edit collection settings** to open the advanced settings ---3. Select the checkbox with **Enable ContainerLogV2** and choose the **Save** button below ---4. The summary section should display the message "ContainerLogV2 enabled", click the **Configure** button to complete your configuration change ---## [CLI](#tab/configure-CLI) --1. For configuring via CLI, use the corresponding [config file](./container-insights-cost-config.md#enable-cost-settings), update the `enableContainerLogV2` field in the config file to be true. ---- -### Configure an existing ConfigMap -This applies to the scenario where you have already enabled container insights for your AKS cluster and have [configured agent data collection settings](./container-insights-agent-config.md#configure-and-deploy-configmaps) using ConfigMap "_container-azm-ms-agentconfig.yaml_". If this ConfigMap doesn't yet have the `log_collection_settings.schema` field, you'll need to append the following section in this existing ConfigMap .yaml file: --```yaml -[log_collection_settings.schema] - # In the absence of this ConfigMap, the default value for containerlog_schema_version is "v1" - # Supported values for this setting are "v1","v2" - # See documentation at https://aka.ms/ContainerLogv2 for benefits of v2 schema over v1 schema before opting for "v2" schema - containerlog_schema_version = "v2" -``` --### Configure a new ConfigMap -1. [Download the new ConfigMap](https://aka.ms/container-azm-ms-agentconfig). For the newly downloaded ConfigMap, the default value for `containerlog_schema_version` is `"v2"`. -1. Ensure that the `containerlog_schema_version` to `"v2"` and the `[log_collection_settings.schema]` is also uncommented by removing the `#` preceding it: -- ```yaml - [log_collection_settings.schema] - # In the absence of this ConfigMap, the default value for containerlog_schema_version is "v1" - # Supported values for this setting are "v1","v2" - # See documentation at https://aka.ms/ContainerLogv2 for benefits of v2 schema over v1 schema before opting for "v2" schema - containerlog_schema_version = "v2" - ``` --3. After you finish configuring the ConfigMap, run the following kubectl command: `kubectl apply -f <configname>`. -- Example: `kubectl apply -f container-azm-ms-agentconfig.yaml` -->[!NOTE] ->* The configuration change can take a few minutes to complete before it takes effect. All ama-logs pods in the cluster will restart. ->* The restart is a rolling restart for all ama-logs pods. It won't restart all of them at the same time. --## Multi-line logging in Container Insights -Azure Monitor container insights now supports multiline logging. With this feature enabled, previously split container logs are stitched together and sent as single entries to the ContainerLogV2 table. Customers are able see container log lines upto to 64 KB (up from the existing 16 KB limit). If the stitched log line is larger than 64 KB, it gets truncated due to Log Analytics limits. -Additionally, the feature also adds support for .NET, Go, Python and Java stack traces, which appear as single entries instead of being split into multiple entries in ContainerLogV2 table. --Below are two screenshots which demonstrate Multi-line logging at work for Go exception stack trace: --Multi-line logging disabled scenario: -<!-- convertborder later --> --Multi-line logging enabled scenario: -<!-- convertborder later --> --Similarly, below screenshots depict Multi-line logging enabled scenarios for Java and Python stack traces: --For Java: ---For Python: ---### Pre-requisites --Customers must [enable ContainerLogV2](./container-insights-logging-v2.md#enable-the-containerlogv2-schema) for multi-line logging to work. --### How to enable -Multi-line logging feature can be enabled by setting **enabled** flag to "true" under the `[log_collection_settings.enable_multiline_logs]` section in the [config map](https://github.com/microsoft/Docker-Provider/blob/ci_prod/kubernetes/container-azm-ms-agentconfig.yaml) --```yaml -[log_collection_settings.enable_multiline_logs] -# fluent-bit based multiline log collection for go (stacktrace), dotnet (stacktrace) -# if enabled will also stitch together container logs split by docker/cri due to size limits(16KB per log line) - enabled = "true" -``` --## Next steps -* Configure [Basic Logs](../logs/basic-logs-configure.md) for ContainerLogv2. -* Learn how [query data](./container-insights-log-query.md#container-logs) from ContainerLogV2 - |
azure-monitor | Container Insights Logs Schema | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-logs-schema.md | + + Title: Configure the ContainerLogV2 schema for Container Insights +description: Switch your ContainerLog table to the ContainerLogV2 schema. +++++ Last updated : 08/28/2023++++# Container insights log schema +Container insights stores log data it collects in a table called *ContainerLogV2*. This article describes the schema of this table and its comparison and migration from the legacy *ContainerLog* table. +++>[!IMPORTANT] +> ContainerLogV2 will be the default schema via the ConfigMap for CLI version 2.54.0 and greater. ContainerLogV2 will be default ingestion format for customers who will be onboarding container insights with Managed Identity Auth using ARM, Bicep, Terraform, Policy and Portal onboarding. ContainerLogV2 can be explicitly enabled through CLI version 2.51.0 or higher using Data collection settings. +> +> Support for the *ContainerLog* table will be retired on 30th September 2026. ++ +## Table comparison +The following table highlights the key differences between using ContainerLogV2 and ContainerLog schema. ++| Feature differences | ContainerLog | ContainerLogV2 | +| - | -- | - | +| Schema | Details at [ContainerLog](/azure/azure-monitor/reference/tables/containerlog). | Details at [ContainerLogV2](/azure/azure-monitor/reference/tables/containerlogv2).<br>Additional columns are:<br>- `ContainerName`<br>- `PodName`<br>- `PodNamespace`. | +| Onboarding | Only configurable through ConfigMap. | Configurable through both ConfigMap and DCR. <sup>1</sup>| +| Pricing | Only compatible with full-priced analytics logs. | Supports the low cost [basic logs](../logs/basic-logs-configure.md) tier in addition to analytics logs. | +| Querying | Requires multiple join operations with inventory tables for standard queries. | Includes additional pod and container metadata to reduce query complexity and join operations. | +| Multiline | Not supported, multiline entries are split into multiple rows. | Support for multiline logging to allow consolidated, single entries for multiline output. | ++<sup>1</sup>DCR configuration not supported for clusters using service principal authentication based clusters. [Migrate your clusters with service principal to managed identity](./container-insights-authentication.md) to use this experience. ++>[!NOTE] +> [Export](../logs/logs-data-export.md) to Event Hub and Storage Account is not supported if the incoming LogMessage is not a valid JSON. For best performance, we recommend emitting container logs in JSON format. +++## Assess the impact on existing alerts +Before you enable the **ContainerLogsV2** schema, you should assess whether you have any alert rules that rely on the **ContainerLog** table. Any such alerts will need to be updated to use the new table. ++To scan for alerts that reference the **ContainerLog** table, run the following Azure Resource Graph query: ++```Kusto +resources +| where type in~ ('microsoft.insights/scheduledqueryrules') and ['kind'] !in~ ('LogToMetric') +| extend severity = strcat("Sev", properties["severity"]) +| extend enabled = tobool(properties["enabled"]) +| where enabled in~ ('true') +| where tolower(properties["targetResourceTypes"]) matches regex 'microsoft.operationalinsights/workspaces($|/.*)?' or tolower(properties["targetResourceType"]) matches regex 'microsoft.operationalinsights/workspaces($|/.*)?' or tolower(properties["scopes"]) matches regex 'providers/microsoft.operationalinsights/workspaces($|/.*)?' +| where properties contains "ContainerLog" +| project id,name,type,properties,enabled,severity,subscriptionId +| order by tolower(name) asc +``` ++## Enable the ContainerLogV2 schema +You can enable the **ContainerLogV2** schema for a cluster either using the cluster's Data Collection Rule (DCR) or ConfigMap. If both settings are enabled, the ConfigMap will take precedence. Stdout and stderr logs will only be ingested to the ContainerLog table when both the DCR and ConfigMap are explicitly set to off. ++++## Multi-line logging in Container Insights +With multiline logging enabled, previously split container logs are stitched together and sent as single entries to the ContainerLogV2 table. If the stitched log line is larger than 64 KB, it will be truncated due to Log Analytics workspace limits. This feature also has support for .NET, Go, Python and Java stack traces, which appear as single entries in the ContainerLogV2 table. ++The following screenshots show multi-line logging for Go exception stack trace: ++**Multi-line logging disabled** ++<!-- convertborder later --> ++**Multi-line logging enabled** ++<!-- convertborder later --> ++**Java stack trace** +++**Python stack trace** ++++## Next steps +* Configure [Basic Logs](../logs/basic-logs-configure.md) for ContainerLogv2. +* Learn how [query data](./container-insights-log-query.md#container-logs) from ContainerLogV2 + |
azure-monitor | Container Insights Manage Agent | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-manage-agent.md | Title: Manage the Container insights agent | Microsoft Docs -description: This article describes how to manage the most common maintenance tasks with the containerized Log Analytics agent used by Container insights. + Title: Manage the Container insights agent +description: Describes how to manage the most common maintenance tasks with the containerized Log Analytics agent used by Container insights. Previously updated : 07/21/2020 Last updated : 12/19/2023 ->[!NOTE] ->The Container Insights agent name has changed from OMSAgent to Azure Monitor Agent, along with a few other resource names. This article reflects the new name. Update your commands, alerts, and scripts that reference the old name. Read more about the name change in [our blog post](https://techcommunity.microsoft.com/t5/azure-monitor-status-archive/name-update-for-agent-and-associated-resources-in-azure-monitor/ba-p/3576810). -> +> [!NOTE] +> If you've already deployed an AKS cluster and enabled monitoring by using either the Azure CLI or a Resource Manager template, you can't use `kubectl` to upgrade, delete, redeploy, or deploy the agent. The template needs to be deployed in the same resource group as the cluster. + ## Upgrade the Container insights agent If the agent upgrade fails for a cluster hosted on AKS, this article also descri ### Upgrade the agent on an AKS cluster -The process to upgrade the agent on an AKS cluster consists of two steps. The first step is to disable monitoring with Container insights by using the Azure CLI. Follow the steps described in the [Disable monitoring](container-insights-optout.md?#azure-cli) article. By using the Azure CLI, you can remove the agent from the nodes in the cluster without affecting the solution and the corresponding data that's stored in the workspace. +The process to upgrade the agent on an AKS cluster consists of two steps. The first step is to disable monitoring with Container insights by using the Azure CLI. Follow the steps described in [Disable Container insights on your Kubernetes cluster](kubernetes-monitoring-disable.md) article. By using the Azure CLI, you can remove the agent from the nodes in the cluster without affecting the solution and the corresponding data that's stored in the workspace. >[!NOTE] >While you're performing this maintenance activity, the nodes in the cluster aren't forwarding collected data. Performance views won't show data between the time you removed the agent and installed the new version. This command opens your default text editor. After you set the variable, save th To verify the configuration change took effect, select a container in the **Containers** view in Container insights. In the property pane, expand **Environment Variables**. The section should show only the variable created earlier, which is `AZMON_COLLECT_ENV=FALSE`. For all other containers, the **Environment Variables** section should list all the environment variables discovered. To reenable discovery of the environmental variables, apply the same process you used earlier and change the value from `False` to `True`. Then rerun the `kubectl` command to update the container.- ```yaml - name: AZMON_COLLECT_ENV value: "True" ``` ## Semantic version update of container insights agent version -Container Insights has shifted the image version and naming convention to [semver format] (https://semver.org/). SemVer helps developers keep track of every change made to a software during its development phase and ensures that the software versioning is consistent and meaningful. The old version was in format of ciprod\<timestamp\>-\<commitId\> and win-ciprod\<timestamp\>-\<commitId\>, our first image versions using the Semver format are 3.1.4 for Linux and win-3.1.4 for Windows. +Container Insights has shifted the image version and naming convention to [semver format] (https://semver.org/). SemVer helps developers keep track of every change made to software during its development phase and ensures that the software versioning is consistent and meaningful. The old version was in format of ciprod\<timestamp\>-\<commitId\> and win-ciprod\<timestamp\>-\<commitId\>, our first image versions using the Semver format are 3.1.4 for Linux and win-3.1.4 for Windows. Semver is a universal software versioning schema that's defined in the format MAJOR.MINOR.PATCH, which follows the following constraints: With the rise of Kubernetes and the OSS ecosystem, Container Insights migrate to ## Repair duplicate agents -Customers who manually enable Container Insights using custom methods prior to October 2022 can end up with multiple versions of our agent running together. To clear this duplication, customers are recommended to follow the steps below: +If you manually enabled Container Insights using custom methods prior to October 2022, you can end up with multiple versions of the agent running together. Follow the steps below to clear this duplication. -### Migration guidelines for AKS clusters -1. Get details of customer's custom settings, such as memory and CPU limits on omsagent containers. +1. Gather details of any custom settings, such as memory and CPU limits on your omsagent containers. -2. Review Resource Limits: +2. Review default resource limits for ama-logs and determine if they meet your needs. If not, you may need to create a support topic to help investigate and toggle memory/cpu limits. This can help address the scale limitations issues that some customers encountered previously that resulted in OOMKilled exceptions. -Current ama-logs default limit are below + | OS | Controller Name | Default Limits | + |||| + | Linux | ds-cpu-limit-linux | 500m | + | Linux | ds-memory-limit-linux | 750Mi | + | Linux | rs-cpu-limit | 1 | + | Linux | rs-memory-limit | 1.5Gi | + | Windows | ds-cpu-limit-windows | 500m | + | Windows | ds-memory-limit-windows | 1Gi | -| OS | Controller Name | Default Limits | -|||| -| Linux | ds-cpu-limit-linux | 500m | -| Linux | ds-memory-limit-linux | 750Mi | -| Linux | rs-cpu-limit | 1 | -| Linux | rs-memory-limit | 1.5Gi | -| Windows | ds-cpu-limit-windows | 500m | -| Windows | ds-memory-limit-windows | 1Gi | --Validate whether the current default settings and limits meet the customer's needs. And if not, create support tickets under containerinsights agent to help investigate and toggle memory/cpu limits for the customer. Through doing this, it can help address the scale limitations issues that some customers encountered previously that resulted in OOMKilled exceptions. --3. Fetch current Azure analytic workspace ID since we're going to re-onboard the container insights. --```console -az aks show -g $resourceGroupNameofCluster -n $nameofTheCluster | grep logAnalyticsWorkspaceResourceID` -``` 4. Clean resources from previous onboarding: -**For customers that previously onboarded to containerinsights through helm chart** : --ΓÇó List all releases across namespaces with command: --```console - helm list --all-namespaces -``` --ΓÇó Clean the chart installed for containerinsights (or azure-monitor-containers) with command: --```console -helm uninstall <releaseName> --namespace <Namespace> -``` - -**For customers that previously onboarded to containerinsights through yaml deployment** : --ΓÇó Download previous custom deployment yaml file: --```console -curl -LO raw.githubusercontent.com/microsoft/Docker-Provider/ci_dev/kubernetes/omsagent.yaml -``` --ΓÇó Clean the old omsagent chart: --```console -kubectl delete -f omsagent.yaml -``` --5. Disable container insights to clean all related resources with aks command: [Disable Container insights on your Azure Kubernetes Service (AKS) cluster - Azure Monitor | Microsoft Learn](https://learn.microsoft.com/azure/azure-monitor/containers/container-insights-optout) --```console -az aks disable-addons -a monitoring -n MyExistingManagedCluster -g MyExistingManagedClusterRG -``` --6. Re-onboard to containerinsights with the workspace fetched from step 3 using [the steps outlined here](https://learn.microsoft.com/azure/azure-monitor/containers/container-insights-enable-aks?tabs=azure-cli#specify-a-log-analytics-workspace) + **If you previously onboarded using helm chart** : + + List all releases across namespaces with the following command: + + ```console + helm list --all-namespaces + ``` + + Clean the chart installed for Container insights with the following command: + + ```console + helm uninstall <releaseName> --namespace <Namespace> + ``` ++ **If you previously onboarded using yaml deployment** : + + Download previous custom deployment yaml file with the following command: + + ```console + curl -LO raw.githubusercontent.com/microsoft/Docker-Provider/ci_dev/kubernetes/omsagent.yaml + ``` + + Clean the old omsagent chart with the following command: + + ```console + kubectl delete -f omsagent.yaml + ``` ++5. Disable Container insights to clean all related resources using the guidance at [Disable Container insights on your Kubernetes cluster](../containers/kubernetes-monitoring-disable.md) +++6. Re-onboard to Container insights using the guidance at [Enable Container insights on your Kubernetes cluster](kubernetes-monitoring-enable.md) |
azure-monitor | Container Insights Metric Alerts | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-metric-alerts.md | Title: Create metric alert rules in Container insights (preview) + Title: Metric alert rules for Kubernetes clusters (preview) description: Describes how to create recommended metric alerts rules for a Kubernetes cluster in Container insights. Last updated 03/13/2023 -# Metric alert rules in Container insights (preview) +# Metric alert rules for Kubernetes clusters (preview) Metric alerts in Azure Monitor proactively identify issues related to system resources of your Azure resources, including monitored Kubernetes clusters. Container insights provides preconfigured alert rules so that you don't have to create your own. This article describes the different types of alert rules you can create and how to enable and configure them. The following metrics have unique behavior characteristics: **Prometheus only** -- If you want to collect `pvUsageExceededPercentage` and analyze it from [metrics explorer](../essentials/metrics-getting-started.md), configure the threshold to a value lower than your alerting threshold. The configuration related to the collection settings for persistent volume utilization thresholds can be overridden in the ConfigMaps file under the section `alertable_metrics_configuration_settings.pv_utilization_thresholds`. For details related to configuring your ConfigMap configuration file, see [Configure alertable metrics ConfigMaps](#configure-alertable-metrics-in-configmaps). Collection of persistent volume metrics with claims in the `kube-system` namespace are excluded by default. To enable collection in this namespace, use the section `[metric_collection_settings.collect_kube_system_pv_metrics]` in the ConfigMap file. For more information, see [Metric collection settings](./container-insights-agent-config.md#metric-collection-settings).+- If you want to collect `pvUsageExceededPercentage` and analyze it from [metrics explorer](../essentials/metrics-getting-started.md), configure the threshold to a value lower than your alerting threshold. The configuration related to the collection settings for persistent volume utilization thresholds can be overridden in the ConfigMaps file under the section `alertable_metrics_configuration_settings.pv_utilization_thresholds`. For details related to configuring your ConfigMap configuration file, see [Configure alertable metrics ConfigMaps](#configure-alertable-metrics-in-configmaps). Collection of persistent volume metrics with claims in the `kube-system` namespace are excluded by default. To enable collection in this namespace, use the section `[metric_collection_settings.collect_kube_system_pv_metrics]` in the ConfigMap file. For more information, see [Metric collection settings](./container-insights-data-collection-configmap.md#data-collection-settings). - The `cpuExceededPercentage`, `memoryRssExceededPercentage`, and `memoryWorkingSetExceededPercentage` metrics are sent when the CPU, memory RSS, and Memory Working set values exceed the configured threshold. The default threshold is 95%. The `cpuThresholdViolated`, `memoryRssThresholdViolated`, and `memoryWorkingSetThresholdViolated` metrics are equal to 0 if the usage percentage is below the threshold and are equal to 1 if the usage percentage is above the threshold. These thresholds are exclusive of the alert condition threshold specified for the corresponding alert rule. If you want to collect these metrics and analyze them from [metrics explorer](../essentials/metrics-getting-started.md), configure the threshold to a value lower than your alerting threshold. The configuration related to the collection settings for their container resource utilization thresholds can be overridden in the ConfigMaps file under the section `[alertable_metrics_configuration_settings.container_resource_utilization_thresholds]`. For details related to configuring your ConfigMap configuration file, see the section [Configure alertable metrics ConfigMaps](#configure-alertable-metrics-in-configmaps). ## View alerts |
azure-monitor | Container Insights Onboard | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-onboard.md | - Title: Enable Container insights -description: This article describes how to enable and configure Container insights so that you can understand how your container is performing and what performance-related issues have been identified. -- Previously updated : 10/18/2023----# Enable Container insights --This article provides an overview of the requirements and options that are available for enabling [Container insights](../containers/container-insights-overview.md) on your Kubernetes clusters. You can enable Container insights for a new deployment or for one or more existing deployments of Kubernetes by using several supported methods. --## Supported configurations --Container insights supports the following environments: -- [Azure Kubernetes Service (AKS)](../../aks/index.yml)-- Following [Azure Arc-enabled Kubernetes cluster distributions](../../azure-arc/kubernetes/validation-program.md):- - AKS on Azure Stack HCI - - AKS Edge Essentials - - Canonical - - Cluster API Provider on Azure - - K8s on Azure Stack Edge - - Red Hat OpenShift version 4.x - - SUSE Rancher (Rancher Kubernetes engine) - - SUSE Rancher K3s - - VMware (ie. TKG) --> [!NOTE] -> Container insights supports ARM64 nodes on AKS. See [Cluster requirements](../../azure-arc/kubernetes/system-requirements.md#cluster-requirements) for the details of Azure Arc-enabled clusters that support ARM64 nodes. ---## Prerequisites --- Container insights stores its data in a [Log Analytics workspace](../logs/log-analytics-workspace-overview.md). It supports workspaces in the regions that are listed in [Products available by region](https://azure.microsoft.com/global-infrastructure/services/?regions=all&products=monitor). For a list of the supported mapping pairs to use for the default workspace, see [Region mappings supported by Container insights](container-insights-region-mapping.md). You can let the onboarding experience create a Log Analytics workspace in the default resource group of the AKS cluster subscription. If you already have a workspace, you'll probably want to use that one. For more information, see [Designing your Azure Monitor Logs deployment](../logs/design-logs-deployment.md).-- Permissions- - To enable Container insights, you require must have at least [Contributor](../../role-based-access-control/built-in-roles.md#contributor) access to the AKS cluster. - - To view data after container monitoring is enabled, you must have [Monitoring Reader](../roles-permissions-security.md#monitoring-reader) or [Monitoring Contributor](../roles-permissions-security.md#monitoring-contributor) role. --## Authentication --Container insights uses managed identity authentication. This authentication model has a monitoring agent that uses the cluster's managed identity to send data to Azure Monitor. Read more in [Authentication for Container Insights](container-insights-authentication.md) including guidance on migrating from legacy authentication models. --> [!Note] -> [ContainerLogV2](container-insights-logging-v2.md) is the default schema when you onboard Container insights with using ARM, Bicep, Terraform, Policy and Portal onboarding. ContainerLogV2 can be explicitly enabled through CLI version 2.51.0 or higher using Data collection settings. ---## Agent --Container insights relies on a containerized [Azure Monitor agent](../agents/agents-overview.md) for Linux. This specialized agent collects performance and event data from all nodes in the cluster and sends it to a Log Analytics workspace. The agent is automatically deployed and registered with the specified Log Analytics workspace during deployment. --### Data collection rule -[Data collection rules (DCR)](../essentials/data-collection-rule-overview.md) contain the definition of data that should be collected by Azure Monitor agent. When you enable Container insights on a cluster, a DCR is created with the name *MSCI-\<cluster-region\>-<\cluster-name\>*. Currently, this name can't be modified. --Since March 1, 2023 Container insights uses a semver compliant agent version. The agent version is *mcr.microsoft.com/azuremonitor/containerinsights/ciprod:3.1.4* or later. It's represented by the format mcr.microsoft.com/azuremonitor/containerinsights/ciprod:\<semver compatible version\>. When a new version of the agent is released, it's automatically upgraded on your managed Kubernetes clusters that are hosted on AKS. To track which versions are released, see [Agent release announcements](https://github.com/microsoft/Docker-Provider/blob/ci_prod/ReleaseNotes.md). --> [!NOTE] -> Ingestion Transformations are not currently supported with the [Container insights DCR](../essentials/data-collection-transformations.md). ---### Log Analytics agent --When Container insights doesn't use managed identity authentication, it relies on a containerized [Log Analytics agent for Linux](../agents/log-analytics-agent.md). The agent version is *microsoft/oms:ciprod04202018* or later. It's represented by a date in the following format: *mmddyyyy*. When a new version of the agent is released, it's automatically upgraded on your managed Kubernetes clusters that are hosted on AKS. To track which versions are released, see [Agent release announcements](https://github.com/microsoft/docker-provider/tree/ci_feature_prod). --With the general availability of Windows Server support for AKS, an AKS cluster with Windows Server nodes has a preview agent installed as a daemon set pod on each individual Windows Server node to collect logs and forward them to Log Analytics. For performance metrics, a Linux node that's automatically deployed in the cluster as part of the standard deployment collects and forwards the data to Azure Monitor for all Windows nodes in the cluster. --> [!NOTE] -> If you've already deployed an AKS cluster and enabled monitoring by using either the Azure CLI or a Resource Manager template, you can't use `kubectl` to upgrade, delete, redeploy, or deploy the agent. The template needs to be deployed in the same resource group as the cluster. ---## Differences between Windows and Linux clusters --The main differences in monitoring a Windows Server cluster compared to a Linux cluster include: --- Windows doesn't have a Memory RSS metric. As a result, it isn't available for Windows nodes and containers. The [Working Set](/windows/win32/memory/working-set) metric is available.-- Disk storage capacity information isn't available for Windows nodes.-- Only pod environments are monitored, not Docker environments.-- With the preview release, a maximum of 30 Windows Server containers are supported. This limitation doesn't apply to Linux containers.-->[!NOTE] -> Container insights support for the Windows Server 2022 operating system is in preview. ---The containerized Linux agent (replicaset pod) makes API calls to all the Windows nodes on Kubelet secure port (10250) within the cluster to collect node and container performance-related metrics. Kubelet secure port (:10250) should be opened in the cluster's virtual network for both inbound and outbound for Windows node and container performance-related metrics collection to work. --If you have a Kubernetes cluster with Windows nodes, review and configure the network security group and network policies to make sure the Kubelet secure port (:10250) is open for both inbound and outbound in the cluster's virtual network. ---## Network firewall requirements --The following table lists the proxy and firewall configuration information required for the containerized agent to communicate with Container insights. All network traffic from the agent is outbound to Azure Monitor. --**Azure public cloud** --| Endpoint |Port | -|--|| -| `*.ods.opinsights.azure.com` | 443 | -| `*.oms.opinsights.azure.com` | 443 | -| `dc.services.visualstudio.com` | 443 | -| `*.monitoring.azure.com` | 443 | -| `login.microsoftonline.com` | 443 | --The following table lists the extra firewall configuration required for managed identity authentication. --|Agent resource| Purpose | Port | -|--||| -| `global.handler.control.monitor.azure.com` | Access control service | 443 | -| `<cluster-region-name>.ingest.monitor.azure.com` | Azure monitor managed service for Prometheus - metrics ingestion endpoint (DCE) | 443 | -| `<cluster-region-name>.handler.control.monitor.azure.com` | Fetch data collection rules for specific AKS cluster | 443 | --**Microsoft Azure operated by 21Vianet cloud** --The following table lists the proxy and firewall configuration information for Azure operated by 21Vianet. --|Agent resource| Purpose | Port | -|--||-| -| `*.ods.opinsights.azure.cn` | Data ingestion | 443 | -| `*.oms.opinsights.azure.cn` | OMS onboarding | 443 | -| `dc.services.visualstudio.com` | For agent telemetry that uses Azure Public Cloud Application Insights | 443 | --The following table lists the extra firewall configuration required for managed identity authentication. --|Agent resource| Purpose | Port | -|--||| -| `global.handler.control.monitor.azure.cn` | Access control service | 443 | -| `<cluster-region-name>.handler.control.monitor.azure.cn` | Fetch data collection rules for specific AKS cluster | 443 | --**Azure Government cloud** --The following table lists the proxy and firewall configuration information for Azure US Government. --| Endpoint | Purpose | Port | -|--||-| -| `*.ods.opinsights.azure.us` | Data ingestion | 443 | -| `*.oms.opinsights.azure.us` | OMS onboarding | 443 | -| `dc.services.visualstudio.com` | For agent telemetry that uses Azure Public Cloud Application Insights | 443 | --The following table lists the extra firewall configuration required for managed identity authentication. --|Agent resource| Purpose | Port | -|--||| -| `global.handler.control.monitor.azure.us` | Access control service | 443 | -| `<cluster-region-name>.handler.control.monitor.azure.us` | Fetch data collection rules for specific AKS cluster | 443 | ---## Troubleshooting -If you registered your cluster and/or configured HCI Insights before November 2023, features that use the AMA agent on HCI, such as Arc for Servers Insights, VM Insights, Container Insights, Defender for Cloud or Sentinel might not be collecting logs and event data properly. See [Repair AMA agent for HCI](/azure-stack/hci/manage/monitor-hci-single?tabs=22h2-and-later) for steps to reconfigure the AMA agent and HCI Insights. --## Next steps --After you've enabled monitoring, you can begin analyzing the performance of your Kubernetes clusters that are hosted on AKS, Azure Stack, or another environment. --To learn how to use Container insights, see [View Kubernetes cluster performance](container-insights-analyze.md). -- |
azure-monitor | Container Insights Optout Hybrid | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-optout-hybrid.md | - Title: Disable Container insights on your hybrid Kubernetes cluster -description: This article describes how you can stop monitoring of your hybrid Kubernetes cluster with Container insights. - Previously updated : 08/21/2023----# Disable Container insights on your hybrid Kubernetes cluster --This article shows how to disable Container insights for the following Kubernetes environments: --- AKS Engine on Azure and Azure Stack-- OpenShift version 4 and higher-- Azure Arc-enabled Kubernetes (preview)--## How to stop monitoring using Helm --The following steps apply to the following environments: --- AKS Engine on Azure and Azure Stack-- OpenShift version 4 and higher--1. To first identify the Container insights helm chart release installed on your cluster, run the following helm command. -- ``` - helm list - ``` -- The output resembles the following: -- ``` - NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION - azmon-containers-release-1 default 3 2020-04-21 15:27:24.1201959 -0700 PDT deployed azuremonitor-containers-2.7.0 7.0.0-1 - ``` -- *azmon-containers-release-1* represents the helm chart release for Container insights. --2. To delete the chart release, run the following helm command. -- `helm delete <releaseName>` -- Example: -- `helm delete azmon-containers-release-1` -- This removes the release from the cluster. You can verify by running the `helm list` command: -- ``` - NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION - ``` --The configuration change can take a few minutes to complete. Because Helm tracks your releases even after youΓÇÖve deleted them, you can audit a clusterΓÇÖs history, and even undelete a release with `helm rollback`. --## How to stop monitoring on Azure Arc-enabled Kubernetes --### Using PowerShell --1. Download and save the script to a local folder that configures your cluster with the monitoring add-on using the following commands: -- ```powershell - wget https://aka.ms/disable-monitoring-powershell-script -OutFile disable-monitoring.ps1 - ``` --2. Configure the `$azureArcClusterResourceId` variable by setting the corresponding values for `subscriptionId`, `resourceGroupName` and `clusterName` representing the resource ID of your Azure Arc-enabled Kubernetes cluster resource. -- ```powershell - $azureArcClusterResourceId = "/subscriptions/<subscriptionId>/resourceGroups/<resourceGroupName>/providers/Microsoft.Kubernetes/connectedClusters/<clusterName>" - ``` --3. Configure the `$kubeContext` variable with the **kube-context** of your cluster by running the command `kubectl config get-contexts`. If you want to use the current context, set the value to `""`. -- ```powershell - $kubeContext = "<kubeContext name of your k8s cluster>" - ``` --4. Run the following command to stop monitoring the cluster. -- ```powershell - .\disable-monitoring.ps1 -clusterResourceId $azureArcClusterResourceId -kubeContext $kubeContext - ``` --#### Using service principal -The script *disable-monitoring.ps1* uses the interactive device login. If you prefer non-interactive login, you can use an existing service principal or create a new one that has the required permissions as described in [Prerequisites](container-insights-enable-arc-enabled-clusters.md#prerequisites). To use service principal, you have to pass $servicePrincipalClientId, $servicePrincipalClientSecret and $tenantId parameters with values of service principal you have intended to use to enable-monitoring.ps1 script. --```powershell -$subscriptionId = "<subscription Id of the Azure Arc-connected cluster resource>" -$servicePrincipal = New-AzADServicePrincipal -Role Contributor -Scope "/subscriptions/$subscriptionId" --$servicePrincipalClientId = $servicePrincipal.ApplicationId.ToString() -$servicePrincipalClientSecret = [System.Net.NetworkCredential]::new("", $servicePrincipal.Secret).Password -$tenantId = (Get-AzSubscription -SubscriptionId $subscriptionId).TenantId -``` --For example: --```powershell -\disable-monitoring.ps1 -clusterResourceId $azureArcClusterResourceId -kubeContext $kubeContext -servicePrincipalClientId $servicePrincipalClientId -servicePrincipalClientSecret $servicePrincipalClientSecret -tenantId $tenantId -``` ---### Using bash --1. Download and save the script to a local folder that configures your cluster with the monitoring add-on using the following commands: -- ```bash - curl -o disable-monitoring.sh -L https://aka.ms/disable-monitoring-bash-script - ``` --2. Configure the `azureArcClusterResourceId` variable by setting the corresponding values for `subscriptionId`, `resourceGroupName` and `clusterName` representing the resource ID of your Azure Arc-enabled Kubernetes cluster resource. -- ```bash - export AZUREARCCLUSTERRESOURCEID="/subscriptions/<subscriptionId>/resourceGroups/<resourceGroupName>/providers/Microsoft.Kubernetes/connectedClusters/<clusterName>" - ``` --3. Configure the `kubeContext` variable with the **kube-context** of your cluster by running the command `kubectl config get-contexts`. -- ```bash - export KUBECONTEXT="<kubeContext name of your k8s cluster>" - ``` --4. To stop monitoring your cluster, there are different commands provided based on your deployment scenario. -- Run the following command to stop monitoring the cluster using the current context. -- ```bash - bash disable-monitoring.sh --resource-id $AZUREARCCLUSTERRESOURCEID - ``` -- Run the following command to stop monitoring the cluster by specifying a context -- ```bash - bash disable-monitoring.sh --resource-id $AZUREARCCLUSTERRESOURCEID --kube-context $KUBECONTEXT - ``` --#### Using service principal -The bash script *disable-monitoring.sh* uses the interactive device login. If you prefer non-interactive login, you can use an existing service principal or create a new one that has the required permissions as described in [Prerequisites](container-insights-enable-arc-enabled-clusters.md#prerequisites). To use service principal, you have to pass --client-id, --client-secret and --tenant-id values of service principal you have intended to use to *enable-monitoring.sh* bash script. --```bash -SUBSCRIPTIONID="<subscription Id of the Azure Arc-connected cluster resource>" -SERVICEPRINCIPAL=$(az ad sp create-for-rbac --role="Contributor" --scopes="/subscriptions/${SUBSCRIPTIONID}") -SERVICEPRINCIPALCLIENTID=$(echo $SERVICEPRINCIPAL | jq -r '.appId') --SERVICEPRINCIPALCLIENTSECRET=$(echo $SERVICEPRINCIPAL | jq -r '.password') -TENANTID=$(echo $SERVICEPRINCIPAL | jq -r '.tenant') -``` --For example: --```bash -bash disable-monitoring.sh --resource-id $AZUREARCCLUSTERRESOURCEID --kube-context $KUBECONTEXT --client-id $SERVICEPRINCIPALCLIENTID --client-secret $SERVICEPRINCIPALCLIENTSECRET --tenant-id $TENANTID -``` --## Next steps --If the Log Analytics workspace was created only to support monitoring the cluster and it's no longer needed, you have to manually delete it. If you are not familiar with how to delete a workspace, see [Delete an Azure Log Analytics workspace](../logs/delete-workspace.md). |
azure-monitor | Container Insights Optout | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-optout.md | - Title: Disable Container insights on your Azure Kubernetes Service (AKS) cluster -description: This article describes how you can discontinue monitoring of your Azure AKS cluster with Container insights. - Previously updated : 08/21/2023-----# Disable Container insights on your Azure Kubernetes Service (AKS) cluster --After you enable monitoring of your Azure Kubernetes Service (AKS) cluster, you can stop monitoring the cluster if you decide you no longer want to monitor it. This article shows you how to do this task by using the Azure CLI or the provided Azure Resource Manager templates (ARM templates). --## Azure CLI --Use the [az aks disable-addons](/cli/azure/aks#az-aks-disable-addons) command to disable Container insights. The command removes the agent from the cluster nodes. It doesn't remove the solution or the data already collected and stored in your Azure Monitor resource. --```azurecli -az aks disable-addons -a monitoring -n MyExistingManagedCluster -g MyExistingManagedClusterRG -``` --To reenable monitoring for your cluster, see [Enable monitoring by using the Azure CLI](container-insights-enable-new-cluster.md#enable-using-azure-cli). --## Azure Resource Manager template --Two ARM templates are provided to support removing the solution resources consistently and repeatedly in your resource group. One is a JSON template that specifies the configuration to stop monitoring. The other template contains parameter values that you configure to specify the AKS cluster resource ID and resource group in which the cluster is deployed. --If you're unfamiliar with the concept of deploying resources by using a template, see: --* [Deploy resources with ARM templates and Azure PowerShell](../../azure-resource-manager/templates/deploy-powershell.md) -* [Deploy resources with ARM templates and the Azure CLI](../../azure-resource-manager/templates/deploy-cli.md) -->[!NOTE] ->The template must be deployed in the same resource group of the cluster. If you omit any other properties or add-ons when you use this template, they might be removed from the cluster. Examples are `enableRBAC` for Kubernetes RBAC policies implemented in your cluster, or `aksResourceTagValues`, if tags are specified for the AKS cluster. -> --If you choose to use the Azure CLI, you must install and use the CLI locally. You must be running the Azure CLI version 2.0.27 or later. To identify your version, run `az --version`. If you need to install or upgrade the Azure CLI, see [Install the Azure CLI](/cli/azure/install-azure-cli). --### Create a template --1. Copy and paste the following JSON syntax into your file: -- ```json - { - "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#", - "contentVersion": "1.0.0.0", - "parameters": { - "aksResourceId": { - "type": "string", - "metadata": { - "description": "AKS Cluster Resource ID" - } - }, - "aksResourceLocation": { - "type": "string", - "metadata": { - "description": "Location of the AKS resource e.g. \"East US\"" - } - }, - "aksResourceTagValues": { - "type": "object", - "metadata": { - "description": "Existing all tags on AKS Cluster Resource" - } - } - }, - "resources": [ - { - "name": "[split(parameters('aksResourceId'),'/')[8]]", - "type": "Microsoft.ContainerService/managedClusters", - "location": "[parameters('aksResourceLocation')]", - "tags": "[parameters('aksResourceTagValues')]", - "apiVersion": "2018-03-31", - "properties": { - "mode": "Incremental", - "id": "[parameters('aksResourceId')]", - "addonProfiles": { - "omsagent": { - "enabled": false, - "config": null - } - } - } - } - ] - } - ``` --1. Save this file as **OptOutTemplate.json** to a local folder. --1. Paste the following JSON syntax into your file: -- ```json - { - "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#", - "contentVersion": "1.0.0.0", - "parameters": { - "aksResourceId": { - "value": "/subscriptions/<SubscriptionID>/resourcegroups/<ResourceGroup>/providers/Microsoft.ContainerService/managedClusters/<ResourceName>" - }, - "aksResourceLocation": { - "value": "<aksClusterRegion>" - }, - "aksResourceTagValues": { - "value": { - "<existing-tag-name1>": "<existing-tag-value1>", - "<existing-tag-name2>": "<existing-tag-value2>", - "<existing-tag-nameN>": "<existing-tag-valueN>" - } - } - } - } - ``` --1. Edit the values for **aksResourceId** and **aksResourceLocation** by using the values of the AKS cluster, which you can find on the **Properties** page for the selected cluster. - <!-- convertborder later --> - :::image type="content" source="media/container-insights-optout/container-properties-page.png" lightbox="media/container-insights-optout/container-properties-page.png" alt-text="Screenshot that shows the Container properties page." border="false"::: -- While you're on the **Properties** page, also copy the **Workspace Resource ID**. This value is required if you decide you want to delete the Log Analytics workspace later. Deleting the Log Analytics workspace isn't performed as part of this process. -- Edit the values for **aksResourceTagValues** to match the existing tag values specified for the AKS cluster. --1. Save this file as **OptOutParam.json** to a local folder. --Now you're ready to deploy this template. --### Remove the solution by using the Azure CLI --To remove the solution and clean up the configuration on your AKS cluster, run the following command with the Azure CLI on Linux: --```azurecli -az login -az account set --subscription "Subscription Name" -az deployment group create --resource-group <ResourceGroupName> --template-file ./OptOutTemplate.json --parameters ./OptOutParam.json -``` --The configuration change can take a few minutes to finish. The result is returned in a message similar to the following example: --```output -ProvisioningState : Succeeded -``` --### Remove the solution by using PowerShell ---To remove the solution and clean up the configuration from your AKS cluster, run the following PowerShell commands in the folder that contains the template: --```powershell -Connect-AzAccount -Select-AzSubscription -SubscriptionName <yourSubscriptionName> -New-AzResourceGroupDeployment -Name opt-out -ResourceGroupName <ResourceGroupName> -TemplateFile .\OptOutTemplate.json -TemplateParameterFile .\OptOutParam.json -``` --The configuration change can take a few minutes to finish. The result is returned in a message similar to the following example: --```output -ProvisioningState : Succeeded -``` --## Next steps --If the workspace was created only to support monitoring the cluster and it's no longer needed, you must delete it manually. If you aren't familiar with how to delete a workspace, see [Delete an Azure Log Analytics workspace with the Azure portal](../logs/delete-workspace.md). Don't forget about the **Workspace Resource ID** copied earlier in step 4. You'll need that information. |
azure-monitor | Container Insights Overview | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-overview.md | Title: Overview of Container insights in Azure Monitor description: This article describes Container insights, which monitors the AKS Container insights solution, and the value it delivers by monitoring the health of your AKS clusters and Container Instances in Azure. - Previously updated : 08/14/2023+ Last updated : 12/20/2023 -# Container insights overview +# Overview of Container insights in Azure Monitor -Container insights is a feature of Azure Monitor that monitors the performance and health of container workloads deployed to [Azure](../../aks/intro-kubernetes.md) or that are managed by [Azure Arc-enabled Kubernetes](../../azure-arc/kubernetes/overview.md). It collects memory and processor metrics from controllers, nodes, and containers in addition to gathering container logs. You can analyze the collected data for the different components in your cluster with a collection of [views](container-insights-analyze.md) and pre-built [workbooks](container-insights-reports.md). +Container insights is a feature of Azure Monitor that collects and analyzes container logs from [Azure Kubernetes clusters](../../aks/intro-kubernetes.md) or [Azure Arc-enabled Kubernetes](../../azure-arc/kubernetes/overview.md) clusters and their components. You can analyze the collected data for the different components in your cluster with a collection of [views](container-insights-analyze.md) and prebuilt [workbooks](container-insights-reports.md). -The following video provides an intermediate-level deep dive to help you learn about monitoring your AKS cluster with Container insights. The video refers to *Azure Monitor for Containers*, which is the previous name for *Container insights*. +Container insights works with [Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md) for complete monitoring of your Kubernetes environment. It identifies all clusters across your subscriptions and allows you to quickly enable monitoring by both services. -> [!VIDEO https://www.youtube.com/embed/XEdwGvS2AwA] -## Features of Container insights --Container insights includes the following features to provide to understand the performance and health of your Kubernetes cluster and container workloads: --- Identify resource bottlenecks by identifying containers running on each node and their processor and memory utilization.-- Identify processor and memory utilization of container groups and their containers hosted in container instances.-- View the controller's or pod's overall performance by identifying where the container resides in a controller or a pod.-- Review the resource utilization of workloads running on the host that are unrelated to the standard processes that support the pod.-- Identify capacity needs and determine the maximum load that the cluster can sustain by understanding the behavior of the cluster under average and heaviest loads.-- Access live container logs and metrics generated by the container engine to help with troubleshooting issues in real time.-- Configure alerts to proactively notify you or record when CPU and memory utilization on nodes or containers exceed your thresholds, or when a health state change occurs in the cluster at the infrastructure or nodes health rollup.+> [!IMPORTANT] +> Container insights collects metric data from your cluster in addition to logs. This functionality has been replaced by [Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md). You can analyze that data using built-in dashboards in [Managed Grafana](../../managed-grafan). +> +> You can continue to have Container insights collect metric data so you can use the Container insights monitoring experience. Or you can save cost by disabling this collection and using Grafana for metric analysis. See [Configure data collection in Container insights using data collection rule](container-insights-data-collection-dcr.md) for configuration options. ## Access Container insights -Access Container insights in the Azure portal from **Containers** in the **Monitor** menu or directly from the selected AKS cluster by selecting **Insights**. The Azure Monitor menu gives you the global perspective of all the containers that are deployed and monitored. This information allows you to search and filter across your subscriptions and resource groups. You can then drill into Container insights from the selected container. Access Container insights for a particular AKS container directly from the AKS page. +Access Container insights in the Azure portal from **Containers** in the **Monitor** menu or directly from the selected AKS cluster by selecting **Insights**. The Azure Monitor menu gives you the global perspective of all the containers that are deployed and monitored. This information allows you to search and filter across your subscriptions and resource groups. You can then drill into Container insights from the selected container. Access Container insights for a particular cluster from its page in the Azure portal. :::image type="content" source="media/container-insights-overview/azmon-containers-experience.png" lightbox="media/container-insights-overview/azmon-containers-experience.png" alt-text="Screenshot that shows an overview of methods to access Container insights." border="false"::: ## Data collected-Container insights sends data to [Logs](../logs/data-platform-logs.md) and [Metrics](../essentials/data-platform-metrics.md) where you can analyze it using different features of Azure Monitor. It works with other Azure services such as [Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md) and [Managed Grafana](../../managed-grafan#monitoring-data). +Container insights sends data to a [Log Analytics workspace](../logs/data-platform-logs.md) where you can analyze it using different features of Azure Monitor. This workspace is different than the [Azure Monitor workspace](../essentials/azure-monitor-workspace-overview.md) used by Managed Prometheus. For more information on these other services, see [Monitoring data](../../aks/monitor-aks.md#monitoring-data). ## Supported configurations-Container insights supports the following configurations: --- [Azure Kubernetes Service (AKS)](../../aks/intro-kubernetes.md).-- [Azure Container Instances](../../container-instances/container-instances-overview.md).-- Self-managed Kubernetes clusters hosted on [Azure Stack](/azure-stack/user/azure-stack-kubernetes-aks-engine-overview) or on-premises.-- [Azure Arc-enabled Kubernetes](../../azure-arc/kubernetes/overview.md).-- AKS for ARM64 nodes.--Container insights supports clusters running the Linux and Windows Server 2019 operating system. The container runtimes it supports are Moby and any CRI-compatible runtime such as CRI-O and ContainerD. Docker is no longer supported as a container runtime as of September 2022. For more information about this deprecation, see the [AKS release notes][aks-release-notes]. +Container insights supports the following environments: ++- [Azure Kubernetes Service (AKS)](../../aks/index.yml) +- Following [Azure Arc-enabled Kubernetes cluster distributions](../../azure-arc/kubernetes/validation-program.md): + - AKS on Azure Stack HCI + - AKS Edge Essentials + - Canonical + - Cluster API Provider on Azure + - K8s on Azure Stack Edge + - Red Hat OpenShift version 4.x + - SUSE Rancher (Rancher Kubernetes engine) + - SUSE Rancher K3s + - VMware (TKG) ++> [!NOTE] +> Container insights supports ARM64 nodes on AKS. See [Cluster requirements](../../azure-arc/kubernetes/system-requirements.md#cluster-requirements) for the details of Azure Arc-enabled clusters that support ARM64 nodes. >[!NOTE] > Container insights support for Windows Server 2022 operating system is in public preview. ++## Agent ++Container insights and Managed Prometheus rely on a containerized [Azure Monitor agent](../agents/agents-overview.md) for Linux. This specialized agent collects performance and event data from all nodes in the cluster. The agent is deployed and registered with the specified workspaces during deployment. When you enable Container insights on a cluster, a [Data collection rule (DCR)](../essentials/data-collection-rule-overview.md) is created with the name `MSCI-<cluster-region>-<cluster-name>` that contains the definition of data that should be collected by Azure Monitor agent. ++Since March 1, 2023 Container insights uses a semver compliant agent version. The agent version is *mcr.microsoft.com/azuremonitor/containerinsights/ciprod:3.1.4* or later. When a new version of the agent is released, it will be automatically upgraded on your managed Kubernetes clusters that are hosted on AKS. To track which versions are released, see [Agent release announcements](https://github.com/microsoft/Docker-Provider/blob/ci_prod/ReleaseNotes.md). +++### Log Analytics agent ++When Container insights doesn't use managed identity authentication, it relies on a containerized [Log Analytics agent for Linux](../agents/log-analytics-agent.md). The agent version is *microsoft/oms:ciprod04202018* or later. When a new version of the agent is released, it's automatically upgraded on your managed Kubernetes clusters that are hosted on AKS. To track which versions are released, see [Agent release announcements](https://github.com/microsoft/docker-provider/tree/ci_feature_prod). ++With the general availability of Windows Server support for AKS, an AKS cluster with Windows Server nodes has a preview agent installed as a daemon set pod on each individual Windows Server node to collect logs and forward them to Log Analytics. For performance metrics, a Linux node is automatically deployed in the cluster as part of the standard deployment collects and forwards the data to Azure Monitor for all Windows nodes in the cluster. ++ ## Frequently asked questions This section provides answers to common questions. -### Is there support for collecting Kubernetes audit logs for ARO clusters? -+**Is there support for collecting Kubernetes audit logs for ARO clusters?** No. Container insights don't support collection of Kubernetes audit logs. -### Does Container Insights support pod sandboxing? --Yes, Container Insights supports pod sandboxing through support for Kata Containers. For more details on pod sandboxing in AKS, [refer to the AKS docs](/azure/aks/use-pod-sandboxing). +**Does Container Insights support pod sandboxing?** +Yes, Container Insights supports pod sandboxing through support for Kata Containers. See [Pod Sandboxing (preview) with Azure Kubernetes Service (AKS)](../../aks/use-pod-sandboxing.md). ## Next steps |
azure-monitor | Container Insights Persistent Volumes | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-persistent-volumes.md | Container insights automatically starts monitoring PV usage by collecting the fo |--|--|-| | `pvUsedBytes`| `podUID`, `podName`, `pvcName`, `pvcNamespace`, `capacityBytes`, `clusterId`, `clusterName`| Used space in bytes for a specific persistent volume with a claim used by a specific pod. The `capacityBytes` tag is folded in as a dimension in the Tags field to reduce data ingestion cost and to simplify queries.| -To learn more about how to configure collected PV metrics, see [Configure agent data collection for Container insights](./container-insights-agent-config.md). +To learn more about how to configure collected PV metrics, see [Configure agent data collection for Container insights](./container-insights-data-collection-configmap.md). ## PV inventory You can enable a recommended alert to alert you when average PV usage for a pod ## Next steps -To learn more about collected PV metrics, see [Configure agent data collection for Container insights](./container-insights-agent-config.md). +To learn more about collected PV metrics, see [Configure agent data collection for Container insights](./container-insights-data-collection-configmap.md). |
azure-monitor | Container Insights Troubleshoot | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-troubleshoot.md | The following table summarizes known errors you might encounter when you use Con | Error messages | Action | | - | | | Error message "No data for selected filters" | It might take some time to establish monitoring data flow for newly created clusters. Allow at least 10 to 15 minutes for data to appear for your cluster.<br><br>If data still doesn't show up, check if the Log Analytics workspace is configured for `disableLocalAuth = true`. If yes, update back to `disableLocalAuth = false`.<br><br>`az resource show --ids "/subscriptions/[Your subscription ID]/resourcegroups/[Your resource group]/providers/microsoft.operationalinsights/workspaces/[Your workspace name]"`<br><br>`az resource update --ids "/subscriptions/[Your subscription ID]/resourcegroups/[Your resource group]/providers/microsoft.operationalinsights/workspaces/[Your workspace name]" --api-version "2021-06-01" --set properties.features.disableLocalAuth=False` |-| Error message "Error retrieving data" | While an AKS cluster is setting up for health and performance monitoring, a connection is established between the cluster and a Log Analytics workspace. A Log Analytics workspace is used to store all monitoring data for your cluster. This error might occur when your Log Analytics workspace has been deleted. Check if the workspace was deleted. If it was, reenable monitoring of your cluster with Container insights. Then specify an existing workspace or create a new one. To reenable, [disable](container-insights-optout.md) monitoring for the cluster and [enable](container-insights-enable-new-cluster.md) Container insights again. | +| Error message "Error retrieving data" | While an AKS cluster is setting up for health and performance monitoring, a connection is established between the cluster and a Log Analytics workspace. A Log Analytics workspace is used to store all monitoring data for your cluster. This error might occur when your Log Analytics workspace has been deleted. Check if the workspace was deleted. If it was, reenable monitoring of your cluster with Container insights. Then specify an existing workspace or create a new one. To reenable, [disable](kubernetes-monitoring-disable.md) monitoring for the cluster and [enable](kubernetes-monitoring-enable.md) Container insights again. | | "Error retrieving data" after adding Container insights through `az aks cli` | When you enable monitoring by using `az aks cli`, Container insights might not be properly deployed. Check whether the solution is deployed. To verify, go to your Log Analytics workspace and see if the solution is available by selecting **Legacy solutions** from the pane on the left side. To resolve this issue, redeploy the solution. Follow the instructions in [Enable Container insights](container-insights-onboard.md). | | Error message "Missing Subscription registration" | If you receive the error "Missing Subscription registration for Microsoft.OperationsManagement," you can resolve it by registering the resource provider **Microsoft.OperationsManagement** in the subscription where the workspace is defined. For the steps, see [Resolve errors for resource provider registration](../../azure-resource-manager/templates/error-register-resource-provider.md). | | Error message "The reply url specified in the request doesn't match the reply urls configured for the application: '<application ID\>'." | You might see this error message when you enable live logs. For the solution, see [View container data in real time with Container insights](./container-insights-livedata-setup.md#configure-azure-ad-integrated-authentication). | ContainerLog Reenable collection for these properties for every container log line. -If the first option isn't convenient because of query changes involved, you can reenable collecting these fields. Enable the setting `log_collection_settings.enrich_container_logs` in the agent config map as described in the [data collection configuration settings](./container-insights-agent-config.md). +If the first option isn't convenient because of query changes involved, you can reenable collecting these fields. Enable the setting `log_collection_settings.enrich_container_logs` in the agent config map as described in the [data collection configuration settings](./container-insights-data-collection-configmap.md). > [!NOTE] > We don't recommend the second option for large clusters that have more than 50 nodes. It generates API server calls from every node in the cluster to perform this enrichment. This option also increases data size for every log line collected. If the first option isn't convenient because of query changes involved, you can Here's the scenario: You enabled Container insights for an Azure Kubernetes Service cluster. Then you deleted the Log Analytics workspace where the cluster was sending its data. Now when you attempt to upgrade the cluster, it fails. To work around this issue, you must disable monitoring and then reenable it by referencing a different valid workspace in your subscription. When you try to perform the cluster upgrade again, it should process and complete successfully. ++## Not collecting logs on Azure Stack HCI cluster +If you registered your cluster and/or configured HCI Insights before November 2023, features that use the Azure Monitor agent on HCI, such as Arc for Servers Insights, VM Insights, Container Insights, Defender for Cloud, or Microsoft Sentinel might not be collecting logs and event data properly. See [Repair AMA agent for HCI](/azure-stack/hci/manage/monitor-hci-single?tabs=22h2-and-later#repair-ama-for-azure-stack-hci) for steps to reconfigure the agent and HCI Insights. ++ ## Next steps When monitoring is enabled to capture health metrics for the AKS cluster nodes and pods, these health metrics are available in the Azure portal. To learn how to use Container insights, see [View Azure Kubernetes Service health](container-insights-analyze.md). |
azure-monitor | Container Insights V2 Migration | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/container-insights-v2-migration.md | - Title: Migrate from ContainerLog to ContainerLogV2 -description: This article describes the transition plan from the ContainerLog to ContainerLogV2 table - Previously updated : 07/19/2023----# Migrate from ContainerLog to ContainerLogV2 --With the upgraded offering of ContainerLogV2 becoming generally available, on 30th September 2026, the ContainerLog table will be retired. If you currently ingest container insights data to the ContainerLog table, transition to using ContainerLogV2 prior to that date. -->[!NOTE] -> Support for ingesting the ContainerLog table will be **retired on 30th September 2026**. --## Steps to complete the transition --To transition to ContainerLogV2, we recommend the following approach. --1. Learn about the feature differences between ContainerLog and ContainerLogV2 -2. Assess the impact migrating to ContainerLogV2 might have on your existing queries, alerts, or dashboards -3. [Enable the ContainerLogV2 schema](container-insights-logging-v2.md) through either the container insights data collection rules (DCRs) or ConfigMap -4. Validate that you're now ingesting ContainerLogV2 to your Log Analytics workspace. --## ContainerLog vs ContainerLogV2 schema --The following table highlights the key differences between using ContainerLog and ContainerLogV2 schema. -->[!NOTE] -> DCR based configuration is not supported for service principal based clusters. [Migrate your clusters with service principal to managed identity](./container-insights-authentication.md) to use this experience. --| Feature differences | ContainerLog | ContainerLogV2 | -| - | -- | - | -| Onboarding | Only configurable through the ConfigMap | Configurable through both the ConfigMap and DCR\* | -| Pricing | Only compatible with full-priced analytics logs | Supports the low cost basic logs tier in addition to analytics logs | -| Querying | Requires multiple join operations with inventory tables for standard queries | Includes additional pod and container metadata to reduce query complexity and join operations | -| Multiline | Not supported, multiline entries are split into multiple rows | Support for multiline logging to allow consolidated, single entries for multiline output | --\* DCR enablement is not supported for service principal based clusters, must be enabled through the ConfigMap --## Assess the impact on existing alerts --If you're currently using ContainerLog in your alerts, then migrating to ContainerLogV2 requires updates to your alert queries for them to continue functioning as expected. --To scan for alerts that might be referencing the ContainerLog table, run the following Azure Resource Graph query: --```Kusto -resources -| where type in~ ('microsoft.insights/scheduledqueryrules') and ['kind'] !in~ ('LogToMetric') -| extend severity = strcat("Sev", properties["severity"]) -| extend enabled = tobool(properties["enabled"]) -| where enabled in~ ('true') -| where tolower(properties["targetResourceTypes"]) matches regex 'microsoft.operationalinsights/workspaces($|/.*)?' or tolower(properties["targetResourceType"]) matches regex 'microsoft.operationalinsights/workspaces($|/.*)?' or tolower(properties["scopes"]) matches regex 'providers/microsoft.operationalinsights/workspaces($|/.*)?' -| where properties contains "ContainerLog" -| project id,name,type,properties,enabled,severity,subscriptionId -| order by tolower(name) asc -``` --## Next steps -- [Enable ContainerLogV2](container-insights-logging-v2.md) |
azure-monitor | Kubernetes Monitoring Disable | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/kubernetes-monitoring-disable.md | + + Title: Disable monitoring of your Kubernetes cluster +description: Describes how to remove Container insights and scraping of Prometheus metrics from your Kubernetes cluster. + Last updated : 12/14/2023++ms.devlang: azurecli ++++# Disable monitoring of your Kubernetes cluster ++This article shows you how to stop monitoring your Kubernetes cluster and Remove Container insights. +++## AKS cluster ++### [CLI](#tab/cli) ++#### Prometheus +Currently, the Azure CLI is the only option to remove the metrics add-on from your AKS cluster, and stop sending Prometheus metrics to Azure Monitor managed service for Prometheus. ++The `az aks update --disable-azure-monitor-metrics` command: +++ Removes the ama-metrics agent from the cluster nodes. ++ Deletes the recording rules created for that cluster. ++ Deletes the data collection endpoint (DCE). ++ Deletes the data collection rule (DCR).++ Deletes the DCRA and recording rules groups created as part of onboarding.++> [!NOTE] +> This action doesn't remove any existing data stored in your Azure Monitor workspace. ++```azurecli +az aks update --disable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> +``` ++#### Container insights +Use the [az aks disable-addons](/cli/azure/aks#az-aks-disable-addons) command to disable Container insights. The command removes the agent from the cluster nodes. It doesn't remove the solution or the data already collected and stored in your Azure Monitor resource. ++```azurecli +az aks disable-addons -a monitoring -n MyExistingManagedCluster -g MyExistingManagedClusterRG +``` ++### [Azure Resource Manager](#tab/arm) +++#### Download and install template ++1. Create the template file by saving the following JSON syntax as *OptOutTemplate.json*. ++ ```json + { + "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#", + "contentVersion": "1.0.0.0", + "parameters": { + "aksResourceId": { + "type": "string", + "metadata": { + "description": "AKS Cluster Resource ID" + } + }, + "aksResourceLocation": { + "type": "string", + "metadata": { + "description": "Location of the AKS resource e.g. \"East US\"" + } + }, + "aksResourceTagValues": { + "type": "object", + "metadata": { + "description": "Existing all tags on AKS Cluster Resource" + } + } + }, + "resources": [ + { + "name": "[split(parameters('aksResourceId'),'/')[8]]", + "type": "Microsoft.ContainerService/managedClusters", + "location": "[parameters('aksResourceLocation')]", + "tags": "[parameters('aksResourceTagValues')]", + "apiVersion": "2018-03-31", + "properties": { + "mode": "Incremental", + "id": "[parameters('aksResourceId')]", + "addonProfiles": { + "omsagent": { + "enabled": false, + "config": null + } + } + } + } + ] + } + ``` ++2. Create the template file by saving the following JSON syntax as *OptOutParam.json*. ++3. Edit the following values in the parameter file. Retrieve the resource ID of the resources from the **JSON View** of their **Overview** page. ++ | Parameter | Description | + |:|:| + | `aksResourceId` | Resource ID of the cluster. | + | `aksResourceLocation` | Location of the cluster. | + | `resourceTagValues` | Existing tag values specified for the Container insights cluster. | +++4. Deploy the template with the parameter file by using any valid method for deploying Resource Manager templates. For examples of different methods, see [Deploy the sample templates](../resource-manager-samples.md#deploy-the-sample-templates). ++++## Arc-enabled Kubernetes cluster ++The following scripts are available for removing Container insights from your Arc-enabled Kubernetes clusters. You can get the **kube-context** of your cluster by running the command `kubectl config get-contexts`. If you want to use the current context, then don't specify this parameter. +++PowerShell: [disable-monitoring.ps1](https://aka.ms/disable-monitoring-powershell-script) +Bash: [disable-monitoring.sh](https://aka.ms/disable-monitoring-bash-script) +++```powershell +# Use current context +.\disable-monitoring.ps1 -clusterResourceId <cluster-resource-id> ++# Specify kube-context +.\disable-monitoring.ps1 -clusterResourceId <cluster-resource-id> -kubeContext <kube-context> +``` ++```bash +# Use current context +bash disable-monitoring.sh --resource-id $AZUREARCCLUSTERRESOURCEID ++# Specify kube-context +bash disable-monitoring.sh --resource-id $AZUREARCCLUSTERRESOURCEID --kube-context $KUBECONTEXT +``` ++## Disable monitoring using Helm ++The following steps apply to the following environments: ++- AKS Engine on Azure and Azure Stack +- OpenShift version 4 and higher ++1. Run the following helm command to identify the Container insights helm chart release installed on your cluster ++ ``` + helm list + ``` ++ The output resembles the following: ++ ``` + NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION + azmon-containers-release-1 default 3 2020-04-21 15:27:24.1201959 -0700 PDT deployed azuremonitor-containers-2.7.0 7.0.0-1 + ``` ++ *azmon-containers-release-1* represents the helm chart release for Container insights. ++2. To delete the chart release, run the following helm command. ++ `helm delete <releaseName>` ++ Example: ++ `helm delete azmon-containers-release-1` ++ This removes the release from the cluster. You can verify by running the `helm list` command: ++ ``` + NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION + ``` ++The configuration change can take a few minutes to complete. Because Helm tracks your releases even after youΓÇÖve deleted them, you can audit a clusterΓÇÖs history, and even undelete a release with `helm rollback`. ++## Next steps ++If the workspace was created only to support monitoring the cluster and it's no longer needed, you must delete it manually. If you aren't familiar with how to delete a workspace, see [Delete an Azure Log Analytics workspace with the Azure portal](../logs/delete-workspace.md). Don't forget about the **Workspace Resource ID** copied earlier in step 4. You'll need that information. |
azure-monitor | Kubernetes Monitoring Enable | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/kubernetes-monitoring-enable.md | + + Title: Enable monitoring for Azure Kubernetes Service (AKS) cluster +description: Learn how to enable Container insights and Managed Prometheus on an Azure Kubernetes Service (AKS) cluster. + Last updated : 11/14/2023+++++# Enable monitoring for Kubernetes clusters ++This article describes how to enable complete monitoring of your Kubernetes clusters using the following Azure Monitor features: ++- [Managed Prometheus](../essentials/prometheus-metrics-overview.md) for metric collection +- [Container insights](./container-insights-overview.md) for log collection +- [Managed Grafana](../../managed-grafan) for visualization. ++[Using the Azure portal](#enable-full-monitoring-with-azure-portal), you can enable all of the features at the same time. You can also enable them individually by using the Azure CLI, Azure Resource Manager template, Terraform, or Azure Policy. Each of these methods is described in this article. ++> [!IMPORTANT] +> This article describes onboarding using default configuration settings including managed identity authentication. See [Configure agent data collection for Container insights](container-insights-data-collection-configmap.md) and [Customize scraping of Prometheus metrics in Azure Monitor managed service for Prometheus](prometheus-metrics-scrape-configuration.md) to customize your configuration to ensure that you aren't collecting more data than you require. See [Authentication for Container Insights](container-insights-authentication.md) for guidance on migrating from legacy authentication models. ++## Supported clusters ++This article provides onboarding guidance for the following types of clusters. Any differences in the process for each type are noted in the relevant sections. ++- [Azure Kubernetes clusters (AKS)](../../aks/intro-kubernetes.md) +- [Arc-enabled Kubernetes clusters](../../azure-arc/kubernetes/overview.md) +- [AKS hybrid clusters (preview)](/azure/aks/hybrid/aks-hybrid-options-overview) ++## Prerequisites ++**Permissions** ++- You require at least [Contributor](../../role-based-access-control/built-in-roles.md#contributor) access to the cluster for onboarding. +- You require [Monitoring Reader](../roles-permissions-security.md#monitoring-reader) or [Monitoring Contributor](../roles-permissions-security.md#monitoring-contributor) to view data after monitoring is enabled. ++**Managed Prometheus prerequisites** ++ - The cluster must use [managed identity authentication](../../aks/use-managed-identity.md). + - The following resource providers must be registered in the subscription of the AKS cluster and the Azure Monitor workspace: + - Microsoft.ContainerService + - Microsoft.Insights + - Microsoft.AlertsManagement ++**Arc-Enabled Kubernetes clusters prerequisites** ++ - Prerequisites for [Azure Arc-enabled Kubernetes cluster extensions](../../azure-arc/kubernetes/extensions.md#prerequisites). + - Verify the [firewall requirements](kubernetes-monitoring-firewall.md) in addition to the [Azure Arc-enabled Kubernetes network requirements](../../azure-arc/kubernetes/network-requirements.md). + - If you previously installed monitoring for AKS, ensure that you have [disabled monitoring](kubernetes-monitoring-disable.md) before proceeding to avoid issues during the extension install. + - If you previously installed monitoring on a cluster using a script without cluster extensions, follow the instructions at [Disable Container insights on your hybrid Kubernetes cluster](container-insights-optout-hybrid.md) to delete this Helm chart. ++++## Workspaces ++The following table describes the workspaces that are required to support Managed Prometheus and Container insights. You can create each workspace as part of the onboarding process or use an existing workspace. See [Design a Log Analytics workspace architecture](../logs/workspace-design.md) for guidance on how many workspaces to create and where they should be placed. ++| Feature | Workspace | Notes | +|:|:|:| +| Managed Prometheus | [Azure Monitor workspace](../essentials/azure-monitor-workspace-overview.md) | `Contributor` permission is enough for enabling the addon to send data to the Azure Monitor workspace. You will need `Owner` level permission to link your Azure Monitor Workspace to view metrics in Azure Managed Grafana. This is required because the user executing the onboarding step, needs to be able to give the Azure Managed Grafana System Identity `Monitoring Reader` role on the Azure Monitor Workspace to query the metrics. | +| Container insights | [Log Analytics workspace](../logs/log-analytics-workspace-overview.md) | You can attach an AKS cluster to a Log Analytics workspace in a different Azure subscription in the same Microsoft Entra tenant, but you must use the Azure CLI or an Azure Resource Manager template. You can't currently perform this configuration with the Azure portal.<br><br>If you're connecting an existing AKS cluster to a Log Analytics workspace in another subscription, the *Microsoft.ContainerService* resource provider must be registered in the subscription with the Log Analytics workspace. For more information, see [Register resource provider](../../azure-resource-manager/management/resource-providers-and-types.md#register-resource-provider).<br><br>For a list of the supported mapping pairs to use for the default workspace, see [Region mappings supported by Container insights](container-insights-region-mapping.md). | +| Managed Grafana | [Azure Managed Grafana workspace](../../managed-grafan) to make the Prometheus metrics collected from your cluster available to Grafana dashboards. | +++## Enable Prometheus and Grafana +Use one of the following methods to enable scraping of Prometheus metrics from your cluster and enable Managed Grafana to visualize the metrics. See [Link a Grafana workspace](../../managed-grafan) for options to connect your Azure Monitor workspace and Azure Managed Grafana workspace. ++### [CLI](#tab/cli) ++If you don't specify an existing Azure Monitor workspace in the following commands, the default workspace for the resource group will be used. If a default workspace doesn't already exist in the cluster's region, one with a name in the format `DefaultAzureMonitorWorkspace-<mapped_region>` will be created in a resource group with the name `DefaultRG-<cluster_region>`. ++#### Prerequisites ++- Az CLI version of 2.49.0 or higher is required. +- The aks-preview extension must be [uninstalled from AKS clusters](/cli/azure/azure-cli-extensions-overview) by using the command `az extension remove --name aks-preview`. +- The k8s-extension extension must be installed using the command `az extension add --name k8s-extension`. +- The k8s-extension version 1.4.1 or higher is required. ++#### AKS cluster +Use the `-enable-azure-monitor-metrics` option `az aks create` or `az aks update` (depending whether you're creating a new cluster or updating an existing cluster) to install the metrics add-on that scrapes Prometheus metrics. +++**Sample commands** ++```azurecli +### Use default Azure Monitor workspace +az aks create/update --enable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> ++### Use existing Azure Monitor workspace +az aks create/update --enable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> --azure-monitor-workspace-resource-id <workspace-name-resource-id> ++### Use an existing Azure Monitor workspace and link with an existing Grafana workspace +az aks create/update --enable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> --azure-monitor-workspace-resource-id <azure-monitor-workspace-name-resource-id> --grafana-resource-id <grafana-workspace-name-resource-id> ++### Use optional parameters +az aks create/update --enable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> --ksm-metric-labels-allow-list "namespaces=[k8s-label-1,k8s-label-n]" --ksm-metric-annotations-allow-list "pods=[k8s-annotation-1,k8s-annotation-n]" +``` ++#### Arc-enabled cluster +++```azurecli +### Use default Azure Monitor workspace +az k8s-extension create --name azuremonitor-metrics --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers.Metrics ++## Use existing Azure Monitor workspace +az k8s-extension create --name azuremonitor-metrics --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers.Metrics --configuration-settings azure-monitor-workspace-resource-id=<workspace-name-resource-id> ++### Use an existing Azure Monitor workspace and link with an existing Grafana workspace +az k8s-extension create --name azuremonitor-metrics --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers.Metrics --configuration-settings azure-monitor-workspace-resource-id=<workspace-name-resource-id> grafana-resource-id=<grafana-workspace-name-resource-id> ++### Use optional parameters +az k8s-extension create --name azuremonitor-metrics --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers.Metrics --configuration-settings azure-monitor-workspace-resource-id=<workspace-name-resource-id> grafana-resource-id=<grafana-workspace-name-resource-id> AzureMonitorMetrics.KubeStateMetrics.MetricAnnotationsAllowList="pods=[k8s-annotation-1,k8s-annotation-n]" AzureMonitorMetrics.KubeStateMetrics.MetricsLabelsAllowlist "namespaces=[k8s-label-1,k8s-label-n]" +``` ++Any of the commands can use the following optional parameters: ++- AKS: `--ksm-metric-annotations-allow-list`<br>Arc: `--AzureMonitorMetrics.KubeStateMetrics.MetricAnnotationsAllowList`<br>Comma-separated list of Kubernetes annotations keys used in the resource's kube_resource_annotations metric. For example, kube_pod_annotations is the annotations metric for the pods resource. By default, this metric contains only name and namespace labels. To include more annotations, provide a list of resource names in their plural form and Kubernetes annotation keys that you want to allow for them. A single `*` can be provided for each resource to allow any annotations, but this has severe performance implications. For example, `pods=[kubernetes.io/team,...],namespaces=[kubernetes.io/team],...`.<br> +- AKS: `--ksm-metric-labels-allow-list`<br>Arc: `--AzureMonitorMetrics.KubeStateMetrics.MetricsLabelsAllowlist`<br>Comma-separated list of more Kubernetes label keys that is used in the resource's kube_resource_labels metric kube_resource_labels metric. For example, kube_pod_labels is the labels metric for the pods resource. By default this metric contains only name and namespace labels. To include more labels, provide a list of resource names in their plural form and Kubernetes label keys that you want to allow for them A single `*` can be provided for each resource to allow any labels, but i this has severe performance implications. For example, `pods=[app],namespaces=[k8s-label-1,k8s-label-n,...],...`.<br> +- AKS: `--enable-windows-recording-rules` Lets you enable the recording rule groups required for proper functioning of the Windows dashboards. ++++### [Azure Resource Manager](#tab/arm) ++Both ARM and Bicep templates are provided in this section. ++#### Prerequisites ++- The Azure Monitor workspace and Azure Managed Grafana instance must already be created. +- The template must be deployed in the same resource group as the Azure Managed Grafana instance. +- If the Azure Managed Grafana instance is in a subscription other than the Azure Monitor workspace subscription, register the Azure Monitor workspace subscription with the `Microsoft.Dashboard` resource provider using the guidance at [Register resource provider](../../azure-resource-manager/management/resource-providers-and-types.md#register-resource-provider). +- Users with the `User Access Administrator` role in the subscription of the AKS cluster can enable the `Monitoring Reader` role directly by deploying the template. ++> [!NOTE] +> Currently in Bicep, there's no way to explicitly scope the `Monitoring Reader` role assignment on a string parameter "resource ID" for an Azure Monitor workspace like in an ARM template. Bicep expects a value of type `resource | tenant`. There is also no REST API [spec](https://github.com/Azure/azure-rest-api-specs) for an Azure Monitor workspace. +> +> Therefore, the default scoping for the `Monitoring Reader` role is on the resource group. The role is applied on the same Azure Monitor workspace by inheritance, which is the expected behavior. After you deploy this Bicep template, the Grafana instance is given `Monitoring Reader` permissions for all the Azure Monitor workspaces in that resource group. +++#### Retrieve required values for Grafana resource +If the Azure Managed Grafana instance is already linked to an Azure Monitor workspace, then you must include this list in the template. On the **Overview** page for the Azure Managed Grafana instance in the Azure portal, select **JSON view**, and copy the value of `azureMonitorWorkspaceIntegrations` which will look similar to the sample below. If it doesn't exist, then the instance hasn't been linked with any Azure Monitor workspace. ++```json +"properties": { + "grafanaIntegrations": { + "azureMonitorWorkspaceIntegrations": [ + { + "azureMonitorWorkspaceResourceId": "full_resource_id_1" + }, + { + "azureMonitorWorkspaceResourceId": "full_resource_id_2" + } + ] + } +} +``` ++#### Download and edit template and parameter file ++1. Download the required files for the type of Kubernetes cluster you're working with. ++ **AKS cluster ARM** ++ - Template file: [https://aka.ms/azureprometheus-enable-arm-template](https://aka.ms/azureprometheus-enable-arm-template) + - Parameter file: [https://aka.ms/azureprometheus-enable-arm-template-parameters](https://aka.ms/azureprometheus-enable-arm-template-parameters) ++ **AKS cluster Bicep** ++ - Template file: [https://aka.ms/azureprometheus-enable-bicep-template](https://aka.ms/azureprometheus-enable-bicep-template) + - Parameter file: [https://aka.ms/azureprometheus-enable-bicep-template-parameters](https://aka.ms/azureprometheus-enable-arm-template-parameters) + - DCRA module: [https://aka.ms/nested_azuremonitormetrics_dcra_clusterResourceId](https://aka.ms/nested_azuremonitormetrics_dcra_clusterResourceId) + - Profile module: [https://aka.ms/nested_azuremonitormetrics_profile_clusterResourceId](https://aka.ms/nested_azuremonitormetrics_profile_clusterResourceId) ++ **Arc-Enabled cluster ARM** ++ - Template file: [https://aka.ms/azureprometheus-arc-arm-template](https://aka.ms/azureprometheus-arc-arm-template) + - Parameter file: [https://aka.ms/azureprometheus-arc-arm-template-parameters](https://aka.ms/azureprometheus-arc-arm-template-parameters) ++++2. Edit the following values in the parameter file. The same set of values are used for both the ARM and Bicep templates. Retrieve the resource ID of the resources from the **JSON View** of their **Overview** page. +++ | Parameter | Value | + |:|:| + | `azureMonitorWorkspaceResourceId` | Resource ID for the Azure Monitor workspace. Retrieve from the **JSON view** on the **Overview** page for the Azure Monitor workspace. | + | `azureMonitorWorkspaceLocation` | Location of the Azure Monitor workspace. Retrieve from the **JSON view** on the **Overview** page for the Azure Monitor workspace. | + | `clusterResourceId` | Resource ID for the AKS cluster. Retrieve from the **JSON view** on the **Overview** page for the cluster. | + | `clusterLocation` | Location of the AKS cluster. Retrieve from the **JSON view** on the **Overview** page for the cluster. | + | `metricLabelsAllowlist` | Comma-separated list of Kubernetes labels keys to be used in the resource's labels metric. | + | `metricAnnotationsAllowList` | Comma-separated list of more Kubernetes label keys to be used in the resource's annotations metric. | + | `grafanaResourceId` | Resource ID for the managed Grafana instance. Retrieve from the **JSON view** on the **Overview** page for the Grafana instance. | + | `grafanaLocation` | Location for the managed Grafana instance. Retrieve from the **JSON view** on the **Overview** page for the Grafana instance. | + | `grafanaSku` | SKU for the managed Grafana instance. Retrieve from the **JSON view** on the **Overview** page for the Grafana instance. Use the **sku.name**. | ++++3. Open the template file and update the `grafanaIntegrations` property at the end of the file with the values that you retrieved from the Grafana instance. This will look similar to the following samples. In these samples, `full_resource_id_1` and `full_resource_id_2` were already in the Azure Managed Grafana resource JSON. The final `azureMonitorWorkspaceResourceId` entry is already in the template and is used to link to the Azure Monitor workspace resource ID provided in the parameters file. ++ **ARM** ++ ```json + { + "type": "Microsoft.Dashboard/grafana", + "apiVersion": "2022-08-01", + "name": "[split(parameters('grafanaResourceId'),'/')[8]]", + "sku": { + "name": "[parameters('grafanaSku')]" + }, + "location": "[parameters('grafanaLocation')]", + "properties": { + "grafanaIntegrations": { + "azureMonitorWorkspaceIntegrations": [ + { + "azureMonitorWorkspaceResourceId": "full_resource_id_1" + }, + { + "azureMonitorWorkspaceResourceId": "full_resource_id_2" + }, + { + "azureMonitorWorkspaceResourceId": "[parameters('azureMonitorWorkspaceResourceId')]" + } + ] + } + } + } + ``` +++ **Bicep** ++ ++ ```bicep + resource grafanaResourceId_8 'Microsoft.Dashboard/grafana@2022-08-01' = { + name: split(grafanaResourceId, '/')[8] + sku: { + name: grafanaSku + } + identity: { + type: 'SystemAssigned' + } + location: grafanaLocation + properties: { + grafanaIntegrations: { + azureMonitorWorkspaceIntegrations: [ + { + azureMonitorWorkspaceResourceId: 'full_resource_id_1' + } + { + azureMonitorWorkspaceResourceId: 'full_resource_id_2' + } + { + azureMonitorWorkspaceResourceId: azureMonitorWorkspaceResourceId + } + ] + } + } + } + ``` ++4. Deploy the template with the parameter file by using any valid method for deploying Resource Manager templates. For examples of different methods, see [Deploy the sample templates](../resource-manager-samples.md#deploy-the-sample-templates). +++### [Terraform](#tab/terraform) ++#### Prerequisites ++- The Azure Monitor workspace and Azure Managed Grafana workspace must already be created. +- The template needs to be deployed in the same resource group as the Azure Managed Grafana workspace. +- Users with the User Access Administrator role in the subscription of the AKS cluster can enable the Monitoring Reader role directly by deploying the template. +- If the Azure Managed Grafana instance is in a subscription other than the Azure Monitor Workspaces subscription, register the Azure Monitor Workspace subscription with the `Microsoft.Dashboard` resource provider by following [this documentation](../../azure-resource-manager/management/resource-providers-and-types.md#register-resource-provider). ++#### Retrieve required values for a Grafana resource ++On the **Overview** page for the Azure Managed Grafana instance in the Azure portal, select **JSON view**. ++If you're using an existing Azure Managed Grafana instance that's already linked to an Azure Monitor workspace, you need the list of Grafana integrations. Copy the value of the `azureMonitorWorkspaceIntegrations` field. If it doesn't exist, the instance hasn't been linked with any Azure Monitor workspace. Update the `azure_monitor_workspace_integrations` block in `main.tf` with the list of grafana integrations. ++```.tf + azure_monitor_workspace_integrations { + resource_id = var.monitor_workspace_id[var.monitor_workspace_id1, var.monitor_workspace_id2] + } +``` ++#### Download and edit the templates ++If you're deploying a new AKS cluster using Terraform with managed Prometheus addon enabled, follow these steps: ++1. Download all files under [AddonTerraformTemplate](https://aka.ms/AAkm357). +2. Edit the variables in variables.tf file with the correct parameter values. +3. Run `terraform init -upgrade` to initialize the Terraform deployment. +4. Run `terraform plan -out main.tfplan` to initialize the Terraform deployment. +5. Run `terraform apply main.tfplan` to apply the execution plan to your cloud infrastructure. +++Note: Pass the variables for `annotations_allowed` and `labels_allowed` keys in main.tf only when those values exist. These are optional blocks. ++> [!NOTE] +> Edit the main.tf file appropriately before running the terraform template. Add in any existing azure_monitor_workspace_integrations values to the grafana resource before running the template. Else, older values gets deleted and replaced with what is there in the template during deployment. Users with 'User Access Administrator' role in the subscription of the AKS cluster can enable 'Monitoring Reader' role directly by deploying the template. Edit the grafanaSku parameter if you're using a nonstandard SKU and finally run this template in the Grafana Resource's resource group. ++### [Azure Policy](#tab/policy) ++1. Download Azure Policy template and parameter files. ++ - Template file: [https://aka.ms/AddonPolicyMetricsProfile](https://aka.ms/AddonPolicyMetricsProfile) + - Parameter file: [https://aka.ms/AddonPolicyMetricsProfile.parameters](https://aka.ms/AddonPolicyMetricsProfile.parameters) ++1. Create the policy definition using the following CLI command: ++ `az policy definition create --name "Prometheus Metrics addon" --display-name "Prometheus Metrics addon" --mode Indexed --metadata version=1.0.0 category=Kubernetes --rules AddonPolicyMetricsProfile.rules.json --params AddonPolicyMetricsProfile.parameters.json` ++1. After you create the policy definition, in the Azure portal, select **Policy** and then **Definitions**. Select the policy definition you created. +1. Select **Assign** and fill in the details on the **Parameters** tab. Select **Review + Create**. +1. If you want to apply the policy to an existing cluster, create a **Remediation task** for that cluster resource from **Policy Assignment**. ++After the policy is assigned to the subscription, whenever you create a new cluster without Prometheus enabled, the policy will run and deploy to enable Prometheus monitoring. ++++++## Enable Container insights +Use one of the following methods to enable Container insights on your cluster. Once this is complete, see [Configure agent data collection for Container insights](container-insights-data-collection-configmap.md) to customize your configuration to ensure that you aren't collecting more data than you require. +++### [CLI](#tab/cli) ++Use one of the following commands to enable monitoring of your AKS and Arc-enabled clusters. If you don't specify an existing Log Analytics workspace, the default workspace for the resource group will be used. If a default workspace doesn't already exist in the cluster's region, one will be created with a name in the format `DefaultWorkspace-<GUID>-<Region>`. ++#### Prerequisites ++- Azure CLI version 2.43.0 or higher +- Managed identity authentication is default in CLI version 2.49.0 or higher. +- Azure k8s-extension version 1.3.7 or higher +- Managed identity authentication is the default in k8s-extension version 1.43.0 or higher. +- Managed identity authentication is not supported for Arc-enabled Kubernetes clusters with ARO (Azure Red Hat Openshift) or Windows nodes. Use legacy authentication. +- For CLI version 2.54.0 or higher, the logging schema will be configured to [ContainerLogV2](container-insights-logs-schema.md) using [ConfigMap](container-insights-data-collection-configmap.md). ++#### AKS cluster ++```azurecli +### Use default Log Analytics workspace +az aks enable-addons -a monitoring -n <cluster-name> -g <cluster-resource-group-name> ++### Use existing Log Analytics workspace +az aks enable-addons -a monitoring -n <cluster-name> -g <cluster-resource-group-name> --workspace-resource-id <workspace-resource-id> +``` ++**Example** ++```azurecli +az aks enable-addons -a monitoring -n <cluster-name> -g <cluster-resource-group-name> --workspace-resource-id "/subscriptions/my-subscription/resourceGroups/my-resource-group/providers/Microsoft.OperationalInsights/workspaces/my-workspace" +``` +++#### Arc-enabled cluster ++```azurecli +### Use default Log Analytics workspace +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers ++### Use existing Log Analytics workspace +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings logAnalyticsWorkspaceResourceID=<workspace-resource-id> ++### Use managed identity authentication (default as k8s-extension version 1.43.0) +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.useAADAuth=true ++### Use advanced configuration settings +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.resources.daemonset.limits.cpu=150m amalogs.resources.daemonset.limits.memory=600Mi amalogs.resources.deployment.limits.cpu=1 amalogs.resources.deployment.limits.memory=750Mi ++### On Azure Stack Edge +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.logsettings.custommountpath=/home/data/docker ++``` +++**Example** ++```azurecli +az aks enable-addons -a monitoring -n my-cluster -g my-resource-group --workspace-resource-id "/subscriptions/my-subscription/resourceGroups/my-resource-group/providers/Microsoft.OperationalInsights/workspaces/my-workspace" +``` +++See the [resource requests and limits section of Helm chart](https://github.com/microsoft/Docker-Provider/blob/ci_prod/charts/azuremonitor-containers/values.yaml) for the available configuration settings. ++If the cluster is configured with a forward proxy, then proxy settings are automatically applied to the extension. In the case of a cluster with AMPLS + proxy, proxy config should be ignored. Onboard the extension with the configuration setting `amalogs.ignoreExtensionProxySettings=true`. ++```azurecli +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type connectedClusters --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.ignoreExtensionProxySettings=true +``` ++**Delete extension instance** ++The following command only deletes the extension instance, but doesn't delete the Log Analytics workspace. The data in the Log Analytics resource is left intact. ++```azurecli +az k8s-extension delete --name azuremonitor-containers --cluster-type connectedClusters --cluster-name <cluster-name> --resource-group <resource-group> +``` ++#### AKS hybrid cluster +++```azurecli +### Use default Log Analytics workspace +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type provisionedclusters --cluster-resource-provider "microsoft.hybridcontainerservice" --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.useAADAuth=true ++### Use existing Log Analytics workspace +az k8s-extension create --name azuremonitor-containers --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type provisionedclusters --cluster-resource-provider "microsoft.hybridcontainerservice" --extension-type Microsoft.AzureMonitor.Containers --configuration-settings amalogs.useAADAuth=true --configuration-settings logAnalyticsWorkspaceResourceID=<workspace-resource-id> ++``` ++See the [resource requests and limits section of Helm chart](https://github.com/microsoft/Docker-Provider/blob/ci_prod/charts/azuremonitor-containers/values.yaml) for the available configuration settings. ++**Example** ++```azurecli +az aks enable-addons -a monitoring -n <cluster-name> -g <cluster-resource-group-name> --workspace-resource-id "/subscriptions/my-subscription/resourceGroups/my-resource-group/providers/Microsoft.OperationalInsights/workspaces/my-workspace" +``` ++**Delete extension instance** ++The following command only deletes the extension instance, but doesn't delete the Log Analytics workspace. The data in the Log Analytics resource is left intact. ++```azurecli +az k8s-extension delete --cluster-name <cluster-name> --resource-group <resource-group> --cluster-type provisionedclusters --cluster-resource-provider "microsoft.hybridcontainerservice" --name azuremonitor-containers --yes +``` ++### [Azure Resource Manager](#tab/arm) ++Both ARM and Bicep templates are provided in this section. ++#### Prerequisites + +- The template must be deployed in the same resource group as the cluster. ++#### Download and install template ++1. Download and edit template and parameter file ++ **AKS cluster ARM** + - Template file: [https://aka.ms/aks-enable-monitoring-msi-onboarding-template-file](https://aka.ms/aks-enable-monitoring-msi-onboarding-template-file) + - Parameter file: [https://aka.ms/aks-enable-monitoring-msi-onboarding-template-parameter-file](https://aka.ms/aks-enable-monitoring-msi-onboarding-template-parameter-file) ++ **AKS cluster Bicep** + - Template file (Syslog): [https://aka.ms/enable-monitoring-msi-syslog-bicep-template](https://aka.ms/enable-monitoring-msi-syslog-bicep-template) + - Parameter file (No Syslog): [https://aka.ms/enable-monitoring-msi-syslog-bicep-parameters](https://aka.ms/enable-monitoring-msi-syslog-bicep-parameters) + - Template file (No Syslog): [https://aka.ms/enable-monitoring-msi-bicep-template](https://aka.ms/enable-monitoring-msi-bicep-template) + - Parameter file (No Syslog): [https://aka.ms/enable-monitoring-msi-bicep-parameters](https://aka.ms/enable-monitoring-msi-bicep-parameters) ++ **Arc-enabled cluster ARM** + - Template file: [https://aka.ms/arc-k8s-azmon-extension-msi-arm-template](https://aka.ms/arc-k8s-azmon-extension-msi-arm-template) + - Parameter file: [https://aka.ms/arc-k8s-azmon-extension-msi-arm-template-params](https://aka.ms/arc-k8s-azmon-extension-msi-arm-template-params) + - Template file (legacy authentication): [https://aka.ms/arc-k8s-azmon-extension-arm-template](https://aka.ms/arc-k8s-azmon-extension-arm-template) + - Parameter file (legacy authentication): [https://aka.ms/arc-k8s-azmon-extension-arm-template-params](https://aka.ms/arc-k8s-azmon-extension-arm-template-params) ++2. Edit the following values in the parameter file. The same set of values are used for both the ARM and Bicep templates. Retrieve the resource ID of the resources from the **JSON View** of their **Overview** page. ++ | Parameter | Description | + |:|:| + | AKS: `aksResourceId`<br>Arc: `clusterResourceId` | Resource ID of the cluster. | + | AKS: `aksResourceLocation`<br>Arc: `clusterRegion` | Location of the cluster. | + | AKS: `workspaceResourceId`<br>Arc: `workspaceResourceId` | Resource ID of the Log Analytics workspace. | + | Arc: `workspaceRegion` | Region of the Log Analytics workspace. | + | Arc: `workspaceDomain` | Domain of the Log Analytics workspace.<br>`opinsights.azure.com` for Azure public cloud<br>`opinsights.azure.us` for AzureUSGovernment. | + | AKS: `resourceTagValues` | Tag values specified for the existing Container insights extension data collection rule (DCR) of the cluster and the name of the DCR. The name will be `MSCI-<clusterName>-<clusterRegion>` and this resource created in an AKS clusters resource group. For first time onboarding, you can set arbitrary tag values. | +++3. Deploy the template with the parameter file by using any valid method for deploying Resource Manager templates. For examples of different methods, see [Deploy the sample templates](../resource-manager-samples.md#deploy-the-sample-templates). ++++### [Terraform](#tab/terraform) ++#### New AKS cluster ++1. Download Terraform template file depending on whether you want to enable Syslog collection. ++ **Syslog** + - [https://aka.ms/enable-monitoring-msi-syslog-terraform](https://aka.ms/enable-monitoring-msi-syslog-terraform) ++ **No Syslog** + - [https://aka.ms/enable-monitoring-msi-terraform](https://aka.ms/enable-monitoring-msi-terraform) ++2. Adjust the `azurerm_kubernetes_cluster` resource in *main.tf* based on your cluster settings. +3. Update parameters in *variables.tf* to replace values in "<>" ++ | Parameter | Description | + |:|:| + | `aks_resource_group_name` | Use the values on the AKS Overview page for the resource group. | + | `resource_group_location` | Use the values on the AKS Overview page for the resource group. | + | `cluster_name` | Define the cluster name that you would like to create. | + | `workspace_resource_id` | Use the resource ID of your Log Analytics workspace. | + | `workspace_region` | Use the location of your Log Analytics workspace. | + | `resource_tag_values` | Match the existing tag values specified for the existing Container insights extension data collection rule (DCR) of the cluster and the name of the DCR. The name will match `MSCI-<clusterName>-<clusterRegion>` and this resource is created in the same resource group as the AKS clusters. For first time onboarding, you can set the arbitrary tag values. | + | `enabledContainerLogV2` | Set this parameter value to be true to use the default recommended ContainerLogV2. | + | Cost optimization parameters | Refer to [Data collection parameters](container-insights-cost-config.md#data-collection-parameters) | +++4. Run `terraform init -upgrade` to initialize the Terraform deployment. +5. Run `terraform plan -out main.tfplan` to initialize the Terraform deployment. +6. Run `terraform apply main.tfplan` to apply the execution plan to your cloud infrastructure. +++#### Existing AKS cluster +1. Import the existing cluster resource first with the command: ` terraform import azurerm_kubernetes_cluster.k8s <aksResourceId>` +2. Add the oms_agent add-on profile to the existing azurerm_kubernetes_cluster resource. + ``` + oms_agent { + log_analytics_workspace_id = var.workspace_resource_id + msi_auth_for_monitoring_enabled = true + } + ``` +3. Copy the DCR and DCRA resources from the Terraform templates +4. Run `terraform plan -out main.tfplan` and make sure the change is adding the oms_agent property. Note: If the `azurerm_kubernetes_cluster` resource defined is different during terraform plan, the existing cluster will get destroyed and recreated. +5. Run `terraform apply main.tfplan` to apply the execution plan to your cloud infrastructure. ++> [!TIP] +> - Edit the `main.tf` file appropriately before running the terraform template +> - Data will start flowing after 10 minutes since the cluster needs to be ready first +> - WorkspaceID needs to match the format `/subscriptions/12345678-1234-9876-4563-123456789012/resourceGroups/example-resource-group/providers/Microsoft.OperationalInsights/workspaces/workspaceValue` +> - If resource group already exists, run `terraform import azurerm_resource_group.rg /subscriptions/<Subscription_ID>/resourceGroups/<Resource_Group_Name>` before terraform plan ++### [Azure Policy](#tab/policy) ++#### Azure Portal ++1. From the **Definitions** tab of the **Policy** menu in the Azure portal, create a policy definition with the following details. ++ - **Definition location**: Azure subscription where the policy definition should be stored. + - **Name**: AKS-Monitoring-Addon + - **Description**: Azure custom policy to enable the Monitoring Add-on onto Azure Kubernetes clusters. + - **Category**: Select **Use existing** and then *Kubernetes* from the dropdown list. + - **Policy rule**: Replace the existing sample JSON with the contents of [https://aka.ms/aks-enable-monitoring-custom-policy](https://aka.ms/aks-enable-monitoring-custom-policy). ++1. Select the new policy definition **AKS Monitoring Addon**. +1. Select **Assign** and specify a **Scope** of where the policy should be assigned. +1. Select **Next** and provide the resource ID of the Log Analytics workspace. +1. Create a remediation task if you want to apply the policy to existing AKS clusters in the selected scope. +1. Select **Review + create** to create the policy assignment. ++#### Azure CLI ++1. Download Azure Policy template and parameter files. ++ - Template file: [https://aka.ms/enable-monitoring-msi-azure-policy-template](https://aka.ms/enable-monitoring-msi-azure-policy-template) + - Parameter file: [https://aka.ms/enable-monitoring-msi-azure-policy-parameters](https://aka.ms/enable-monitoring-msi-azure-policy-parameters) +++2. Create the policy definition using the following CLI command: ++ ``` + az policy definition create --name "AKS-Monitoring-Addon-MSI" --display-name "AKS-Monitoring-Addon-MSI" --mode Indexed --metadata version=1.0.0 category=Kubernetes --rules azure-policy.rules.json --params azure-policy.parameters.json + ``` ++2. Create the policy definition using the following CLI command: + + ``` + az policy assignment create --name aks-monitoring-addon --policy "AKS-Monitoring-Addon-MSI" --assign-identity --identity-scope /subscriptions/<subscriptionId> --role Contributor --scope /subscriptions/<subscriptionId> --location <location> --role Contributor --scope /subscriptions/<subscriptionId> -p "{ \"workspaceResourceId\": { \"value\": \"/subscriptions/<subscriptionId>/resourcegroups/<resourceGroupName>/providers/microsoft.operationalinsights/workspaces/<workspaceName>\" } }" + ``` ++After the policy is assigned to the subscription, whenever you create a new cluster without Prometheus enabled, the policy will run and deploy to enable Prometheus monitoring. ++++++++## Enable full monitoring with Azure portal +Using the Azure portal, you can enable both Managed Prometheus and Container insights at the same time. ++> [!NOTE] +> If you want to enabled Managed Prometheus without Container insights, then [enable it from the Azure Monitor workspace](./kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) as described below. ++### New AKS cluster (Prometheus and Container insights) ++When you create a new AKS cluster in the Azure portal, you can enable Prometheus, Container insights, and Grafana from the **Integrations** tab. In the Azure Monitor section, select either **Default configuration** or **Custom configuration** if you want to specify which workspaces to use. You can perform additional configuration once the cluster is created. +++### Existing cluster (Prometheus and Container insights) ++This option enables Container insights and optionally Prometheus and Grafana on an existing AKS cluster. ++1. Either select **Insights** from the cluster's menu OR select **Containers** from the **Monitor** menu, **Unmonitored clusters** tab, and click **Enable** next to a cluster. + 1. If Container insights isn't enabled for the cluster, then you're presented with a screen identifying which of the features have been enabled. Click **Configure monitoring**. ++ :::image type="content" source="media/aks-onboard/configure-monitoring-screen.png" lightbox="media/aks-onboard/configure-monitoring-screen.png" alt-text="Screenshot that shows the configuration screen for a cluster."::: ++ 2. If Container insights has already been enabled on the cluster, select the **Monitoring Settings** button to modify the configuration. ++ :::image type="content" source="media/aks-onboard/monitor-settings-button.png" lightbox="media/aks-onboard/monitor-settings-button.png" alt-text="Screenshot that shows the monitoring settings button for a cluster."::: ++2. **Container insights** will be enabled. **Select** the checkboxes for **Enable Prometheus metrics** and **Enable Grafana** if you also want to enable them for the cluster. If you have existing Azure Monitor workspace and Grafana workspace, then they're selected for you. ++ :::image type="content" source="media/prometheus-metrics-enable/configure-container-insights.png" lightbox="media/prometheus-metrics-enable/configure-container-insights.png" alt-text="Screenshot that shows the dialog box to configure Container insights with Prometheus and Grafana."::: ++3. Click **Advanced settings** to select alternate workspaces or create new ones. The **Cost presets** setting allows you to modify the default collection details to reduce your monitoring costs. See [Enable cost optimization settings in Container insights](./container-insights-cost-config.md) for details. ++ :::image type="content" source="media/aks-onboard/advanced-settings.png" lightbox="media/aks-onboard/advanced-settings.png" alt-text="Screenshot that shows the advanced settings dialog box."::: ++4. Click **Configure** to save the configuration. ++### Existing cluster (Prometheus only) ++This option enables Prometheus metrics on a cluster without enabling Container insights. ++1. Open the **Azure Monitor workspaces** menu in the Azure portal and select your workspace. +1. Select **Monitored clusters** in the **Managed Prometheus** section to display a list of AKS clusters. +1. Select **Configure** next to the cluster you want to enable. ++ :::image type="content" source="media/prometheus-metrics-enable/azure-monitor-workspace-configure-prometheus.png" lightbox="media/prometheus-metrics-enable/azure-monitor-workspace-configure-prometheus.png" alt-text="Screenshot that shows an Azure Monitor workspace with a Prometheus configuration."::: ++### Existing cluster (Add Prometheus) +++1. Select **Containers** from the **Monitor** menu, **Monitored clusters** tab, and click **Configure** next to a cluster in the **Managed Prometheus** column. +++## Enable Windows metrics collection (preview) ++> [!NOTE] +> There is no CPU/Memory limit in windows-exporter-daemonset.yaml so it may over-provision the Windows nodes +> For more details see [Resource reservation](https://kubernetes.io/docs/concepts/configuration/windows-resource-management/#resource-reservation) +> +> As you deploy workloads, set resource memory and CPU limits on containers. This also subtracts from NodeAllocatable and helps the cluster-wide scheduler in determining which pods to place on which nodes. +> Scheduling pods without limits may over-provision the Windows nodes and in extreme cases can cause the nodes to become unhealthy. +++As of version 6.4.0-main-02-22-2023-3ee44b9e of the Managed Prometheus addon container (prometheus_collector), Windows metric collection has been enabled for the AKS clusters. Onboarding to the Azure Monitor Metrics add-on enables the Windows DaemonSet pods to start running on your node pools. Both Windows Server 2019 and Windows Server 2022 are supported. Follow these steps to enable the pods to collect metrics from your Windows node pools. ++1. Manually install windows-exporter on AKS nodes to access Windows metrics. + Enable the following collectors: ++ * `[defaults]` + * `container` + * `memory` + * `process` + * `cpu_info` ++ Deploy the [windows-exporter-daemonset YAML](https://github.com/prometheus-community/windows_exporter/blob/master/kubernetes/windows-exporter-daemonset.yaml) file: ++ ``` + kubectl apply -f windows-exporter-daemonset.yaml + ``` ++1. Apply the [ama-metrics-settings-configmap](https://github.com/Azure/prometheus-collector/blob/main/otelcollector/configmaps/ama-metrics-settings-configmap.yaml) to your cluster. Set the `windowsexporter` and `windowskubeproxy` Booleans to `true`. For more information, see [Metrics add-on settings configmap](./prometheus-metrics-scrape-configuration.md#metrics-add-on-settings-configmap). +1. Enable the recording rules that are required for the out-of-the-box dashboards: ++ * If onboarding using the CLI, include the option `--enable-windows-recording-rules`. + * If onboarding using an ARM template, Bicep, or Azure Policy, set `enableWindowsRecordingRules` to `true` in the parameters file. + * If the cluster is already onboarded, use [this ARM template](https://github.com/Azure/prometheus-collector/blob/kaveesh/windows_recording_rules/AddonArmTemplate/WindowsRecordingRuleGroupTemplate/WindowsRecordingRules.json) and [this parameter file](https://github.com/Azure/prometheus-collector/blob/kaveesh/windows_recording_rules/AddonArmTemplate/WindowsRecordingRuleGroupTemplate/WindowsRecordingRulesParameters.json) to create the rule groups. ++++++## Verify deployment +Use the [kubectl command line tool](../../aks/learn/quick-kubernetes-deploy-cli.md#connect-to-the-cluster) to verify that the agent is deployed properly. ++### Managed Prometheus ++**Verify that the DaemonSet was deployed properly on the Linux node pools** ++```AzureCLI +kubectl get ds ama-metrics-node --namespace=kube-system +``` ++The number of pods should be equal to the number of Linux nodes on the cluster. The output should resemble the following example: ++```output +User@aksuser:~$ kubectl get ds ama-metrics-node --namespace=kube-system +NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE +ama-metrics-node 1 1 1 1 1 <none> 10h +``` ++**Verify that Windows nodes were deployed properly** ++```AzureCLI +kubectl get ds ama-metrics-win-node --namespace=kube-system +``` ++The number of pods should be equal to the number of Windows nodes on the cluster. The output should resemble the following example: ++```output +User@aksuser:~$ kubectl get ds ama-metrics-node --namespace=kube-system +NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE +ama-metrics-win-node 3 3 3 3 3 <none> 10h +``` ++**Verify that the two ReplicaSets were deployed for Prometheus** ++```AzureCLI +kubectl get rs --namespace=kube-system +``` ++The output should resemble the following example: ++```output +User@aksuser:~$kubectl get rs --namespace=kube-system +NAME DESIRED CURRENT READY AGE +ama-metrics-5c974985b8 1 1 1 11h +ama-metrics-ksm-5fcf8dffcd 1 1 1 11h +``` +++### Container insights ++**Verify that the DaemonSets were deployed properly on the Linux node pools** ++```AzureCLI +kubectl get ds ama-logs --namespace=kube-system +``` ++The number of pods should be equal to the number of Linux nodes on the cluster. The output should resemble the following example: ++```output +User@aksuser:~$ kubectl get ds ama-logs --namespace=kube-system +NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE +ama-logs 2 2 2 2 2 beta.kubernetes.io/os=linux 1d +``` ++**Verify that Windows nodes were deployed properly** ++``` +kubectl get ds ama-metrics-win-node --namespace=kube-system +``` ++The number of pods should be equal to the number of Windows nodes on the cluster. The output should resemble the following example: ++```output +User@aksuser:~$ kubectl get ds ama-logs-windows --namespace=kube-system +NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE +ama-logs-windows 2 2 2 2 2 beta.kubernetes.io/os=windows 1d +``` +++**Verify deployment of the Container insights solution** ++``` +kubectl get deployment ama-logs-rs -n=kube-system +``` ++The output should resemble the following example: ++```output +User@aksuser:~$ kubectl get deployment ama-logs-rs -n=kube-system +NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE +ama-logs-rs 1 1 1 1 3h +``` ++**View configuration with CLI** ++Use the `aks show` command to find out whether the solution is enabled, the Log Analytics workspace resource ID, and summary information about the cluster. ++```azurecli +az aks show -g <resourceGroupofAKSCluster> -n <nameofAksCluster> +``` ++The command will return JSON-formatted information about the solution. The `addonProfiles` section should include information on the `omsagent` as in the following example: ++```output +"addonProfiles": { + "omsagent": { + "config": { + "logAnalyticsWorkspaceResourceID": "/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/my-resource-group/providers/microsoft.operationalinsights/workspaces/my-workspace", + "useAADAuth": "true" + }, + "enabled": true, + "identity": null + }, +} +``` +++## Resources provisioned ++When you enable monitoring, the following resources are created in your subscription: ++| Resource Name | Resource Type | Resource Group | Region/Location | Description | +|:|:|:|:|:| +| `MSCI-<aksclusterregion>-<clustername>` | **Data Collection Rule** | Same as cluster | Same as Log Analytics workspace | This data collection rule is for log collection by Azure Monitor agent, which uses the Log Analytics workspace as destination, and is associated to the AKS cluster resource. | +| `MSPROM-<aksclusterregion>-<clustername>` | **Data Collection Rule** | Same as cluster | Same as Azure Monitor workspace | This data collection rule is for prometheus metrics collection by metrics addon, which has the chosen Azure monitor workspace as destination, and also it is associated to the AKS cluster resource | +| `MSPROM-<aksclusterregion>-<clustername>` | **Data Collection endpoint** | Same as cluster | Same as Azure Monitor workspace | This data collection endpoint is used by the above data collection rule for ingesting Prometheus metrics from the metrics addon| + +When you create a new Azure Monitor workspace, the following additional resources are created as part of it ++| Resource Name | Resource Type | Resource Group | Region/Location | Description | +|:|:|:|:|:| +| `<azuremonitor-workspace-name>` | **Data Collection Rule** | MA_\<azuremonitor-workspace-name>_\<azuremonitor-workspace-region>_managed | Same as Azure Monitor Workspace | DCR created when you use OSS Prometheus server to Remote Write to Azure Monitor Workspace. | +| `<azuremonitor-workspace-name>` | **Data Collection Endpoint** | MA_\<azuremonitor-workspace-name>_\<azuremonitor-workspace-region>_managed | Same as Azure Monitor Workspace | DCE created when you use OSS Prometheus server to Remote Write to Azure Monitor Workspace.| + +++## Differences between Windows and Linux clusters ++The main differences in monitoring a Windows Server cluster compared to a Linux cluster include: ++- Windows doesn't have a Memory RSS metric. As a result, it isn't available for Windows nodes and containers. The [Working Set](/windows/win32/memory/working-set) metric is available. +- Disk storage capacity information isn't available for Windows nodes. +- Only pod environments are monitored, not Docker environments. +- With the preview release, a maximum of 30 Windows Server containers are supported. This limitation doesn't apply to Linux containers. ++>[!NOTE] +> Container insights support for the Windows Server 2022 operating system is in preview. +++The containerized Linux agent (replicaset pod) makes API calls to all the Windows nodes on Kubelet secure port (10250) within the cluster to collect node and container performance-related metrics. Kubelet secure port (:10250) should be opened in the cluster's virtual network for both inbound and outbound for Windows node and container performance-related metrics collection to work. ++If you have a Kubernetes cluster with Windows nodes, review and configure the network security group and network policies to make sure the Kubelet secure port (:10250) is open for both inbound and outbound in the cluster's virtual network. ++++## Next steps ++* If you experience issues while you attempt to onboard the solution, review the [Troubleshooting guide](container-insights-troubleshoot.md). +* With monitoring enabled to collect health and resource utilization of your AKS cluster and workloads running on them, learn [how to use](container-insights-analyze.md) Container insights. |
azure-monitor | Kubernetes Monitoring Firewall | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/kubernetes-monitoring-firewall.md | + + Title: Network firewall requirements for monitoring Kubernetes cluster +description: Proxy and firewall configuration information required for the containerized agent to communicate with Managed Prometheus and Container insights. + Last updated : 11/14/2023++++# Network firewall requirements for monitoring Kubernetes cluster ++The following table lists the proxy and firewall configuration information required for the containerized agent to communicate with Managed Prometheus and Container insights. All network traffic from the agent is outbound to Azure Monitor. ++## Azure public cloud ++| Endpoint| Purpose | Port | +|:|:|:| +| `*.ods.opinsights.azure.com` | | 443 | +| `*.oms.opinsights.azure.com` | | 443 | +| `dc.services.visualstudio.com` | | 443 | +| `*.monitoring.azure.com` | | 443 | +| `login.microsoftonline.com` | | 443 | +| `global.handler.control.monitor.azure.com` | Access control service | 443 | +| `<cluster-region-name>.ingest.monitor.azure.com` | Azure monitor managed service for Prometheus - metrics ingestion endpoint (DCE) | 443 | +| `<cluster-region-name>.handler.control.monitor.azure.com` | Fetch data collection rules for specific cluster | 443 | ++## Microsoft Azure operated by 21Vianet cloud ++| Endpoint| Purpose | Port | +|:|:|:| +| `*.ods.opinsights.azure.cn` | Data ingestion | 443 | +| `*.oms.opinsights.azure.cn` | Azure Monitor agent (AMA) onboarding | 443 | +| `dc.services.visualstudio.com` | For agent telemetry that uses Azure Public Cloud Application Insights | 443 | +| `global.handler.control.monitor.azure.cn` | Access control service | 443 | +| `<cluster-region-name>.handler.control.monitor.azure.cn` | Fetch data collection rules for specific cluster | 443 | ++## Azure Government cloud ++| Endpoint| Purpose | Port | +|:|:|:| +| `*.ods.opinsights.azure.us` | Data ingestion | 443 | +| `*.oms.opinsights.azure.us` | Azure Monitor agent (AMA) onboarding | 443 | +| `dc.services.visualstudio.com` | For agent telemetry that uses Azure Public Cloud Application Insights | 443 | +| `global.handler.control.monitor.azure.us` | Access control service | 443 | +| `<cluster-region-name>.handler.control.monitor.azure.us` | Fetch data collection rules for specific cluster | 443 | +++## Next steps ++* If you experience issues while you attempt to onboard the solution, review the [Troubleshooting guide](container-insights-troubleshoot.md). +* With monitoring enabled to collect health and resource utilization of your AKS cluster and workloads running on them, learn [how to use](container-insights-analyze.md) Container insights. |
azure-monitor | Monitor Kubernetes | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/monitor-kubernetes.md | Enable scraping of Prometheus metrics by Azure Monitor managed service for Prome - Select the option **Enable Prometheus metrics** when you [create an AKS cluster](../../aks/learn/quick-kubernetes-deploy-portal.md). - Select the option **Enable Prometheus metrics** when you enable Container insights on an existing [AKS cluster](container-insights-enable-aks.md) or [Azure Arc-enabled Kubernetes cluster](container-insights-enable-arc-enabled-clusters.md).-- Enable for an existing [AKS cluster](../essentials/prometheus-metrics-enable.md) or [Arc-enabled Kubernetes cluster (preview)](../essentials/prometheus-metrics-from-arc-enabled-cluster.md).+- Enable for an existing [AKS cluster](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) or [Arc-enabled Kubernetes cluster (preview)](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana). If you already have a Prometheus environment that you want to use for your AKS clusters, then enable Azure Monitor managed service for Prometheus and then use remote-write to send data to your existing Prometheus environment. You can also [use remote-write to send data from your existing self-managed Prometheus environment to Azure Monitor managed service for Prometheus](../essentials/prometheus-remote-write.md). Once Container insights is enabled for a cluster, perform the following actions - Container insights collects many of the same metric values as [Prometheus](#enable-scraping-of-prometheus-metrics). You can disable collection of these metrics by configuring Container insights to only collect **Logs and events** as described in [Enable cost optimization settings in Container insights](../containers/container-insights-cost-config.md#enable-cost-settings). This configuration disables the Container insights experience in the Azure portal, but you can use Grafana to visualize Prometheus metrics and Log Analytics to analyze log data collected by Container insights. - Reduce your cost for Container insights data ingestion by reducing the amount of data that's collected. -- To improve your query experience with data collected by Container insights and to reduce collection costs, [enable the ContainerLogV2 schema](container-insights-logging-v2.md) for each cluster. If you only use logs for occasional troubleshooting, then consider configuring this table as [basic logs](../logs/basic-logs-configure.md).+- To improve your query experience with data collected by Container insights and to reduce collection costs, [enable the ContainerLogV2 schema](container-insights-logs-schema.md) for each cluster. If you only use logs for occasional troubleshooting, then consider configuring this table as [basic logs](../logs/basic-logs-configure.md). If you have an existing solution for collection of logs, then follow the guidance for that tool or enable Container insights and use the [data export feature of Log Analytics workspace](../logs/logs-data-export.md) to send data to [Azure Event Hubs](../../event-hubs/event-hubs-about.md) to forward to alternate system. |
azure-monitor | Prometheus Metrics Disable | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-metrics-disable.md | - Title: Disable collecting Prometheus metrics on an Azure Kubernetes Service cluster -description: Disable the collection of Prometheus metrics from an Azure Kubernetes Service cluster and remove the agent from the cluster nodes. ---- Previously updated : 07/30/2023----# Disable Prometheus metrics collection from an AKS cluster --Currently, the Azure CLI is the only option to remove the metrics add-on from your AKS cluster, and stop sending Prometheus metrics to Azure Monitor managed service for Prometheus. --The `az aks update --disable-azure-monitor-metrics` command: --+ Removes the ama-metrics agent from the cluster nodes. -+ Deletes the recording rules created for that cluster. -+ Deletes the data collection endpoint (DCE). -+ Deletes the data collection rule (DCR). -+ Deletes the DCRA and recording rules groups created as part of onboarding. --> [!NOTE] -> This action doesn't remove any existing data stored in your Azure Monitor workspace. --```azurecli -az aks update --disable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> -``` --## Next steps --- [See the default configuration for Prometheus metrics](./prometheus-metrics-scrape-default.md)-- [Customize Prometheus metric scraping for the cluster](./prometheus-metrics-scrape-configuration.md)-- [Use Azure Monitor managed service for Prometheus as the data source for Grafana](../essentials/prometheus-grafana.md)-- [Configure self-hosted Grafana to use Azure Monitor managed service for Prometheus](../essentials/prometheus-self-managed-grafana-azure-active-directory.md) |
azure-monitor | Prometheus Metrics Enable | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-metrics-enable.md | - Title: Enable Azure Monitor managed service for Prometheus -description: Enable Azure Monitor managed service for Prometheus and configure data collection from your Azure Kubernetes Service (AKS) cluster. ---- Previously updated : 07/30/2023----# Collect Prometheus metrics from an AKS cluster -This article describes how to configure your Azure Kubernetes Service (AKS) cluster to send data to Azure Monitor managed service for Prometheus. When you perform this configuration, a containerized version of the [Azure Monitor agent](../agents/agents-overview.md) is installed with a metrics extension. This sends data to the Azure Monitor workspace that you specify. --> [!NOTE] -> The process described here doesn't enable [Container insights](../containers/container-insights-overview.md) on the cluster. However, both processes use the Azure Monitor agent. For different methods to enable Container insights on your cluster, see [Enable Container insights](../containers/container-insights-onboard.md).. --The Azure Monitor metrics agent's architecture utilizes a ReplicaSet and a DaemonSet. The ReplicaSet pod scrapes cluster-wide targets such as `kube-state-metrics` and custom application targets that are specified. The DaemonSet pods scrape targets solely on the node that the respective pod is deployed on, such as `node-exporter`. This is so that the agent can scale as the number of nodes and pods on a cluster increases. --## Prerequisites --- You must either have an [Azure Monitor workspace](../essentials/azure-monitor-workspace-overview.md) or [create a new one](../essentials/azure-monitor-workspace-manage.md#create-an-azure-monitor-workspace).-- The cluster must use [managed identity authentication](../../aks/use-managed-identity.md).-- The following resource providers must be registered in the subscription of the AKS cluster and the Azure Monitor workspace:- - Microsoft.ContainerService - - Microsoft.Insights - - Microsoft.AlertsManagement --> [!NOTE] -> `Contributor` permission is enough for enabling the addon to send data to the Azure Monitor workspace. You will need `Owner` level permission in case you're trying to link your Azure Monitor Workspace to view metrics in Azure Managed Grafana. This is required because the user executing the onboarding step, needs to be able to give the Azure Managed Grafana System Identity `Monitoring Reader` role on the Azure Monitor Workspace to query the metrics. -----## Enable Prometheus metric collection -Use any of the following methods to install the Azure Monitor agent on your AKS cluster and send Prometheus metrics to your Azure Monitor workspace. --### [Azure portal](#tab/azure-portal) --There are multiple options to enable Prometheus metrics on your cluster from the Azure portal. --#### New cluster -When you create a new AKS cluster in the Azure portal, you can enable Prometheus, Container insights, and Grafana from the **Integrations** tab. ---#### From the Azure Monitor workspace -This option enables Prometheus metrics on a cluster without enabling Container insights. --1. Open the **Azure Monitor workspaces** menu in the Azure portal and select your workspace. -1. Select **Monitored clusters** in the **Managed Prometheus** section to display a list of AKS clusters. -1. Select **Configure** next to the cluster you want to enable. -- :::image type="content" source="media/prometheus-metrics-enable/azure-monitor-workspace-configure-prometheus.png" lightbox="media/prometheus-metrics-enable/azure-monitor-workspace-configure-prometheus.png" alt-text="Screenshot that shows an Azure Monitor workspace with a Prometheus configuration."::: --#### From an existing cluster monitored with Container insights -This option adds Prometheus metrics to a cluster already enabled for Container insights. --1. Open the **Kubernetes services** menu in the Azure portal and select your AKS cluster. -2. Click **Insights**. -3. Click **Monitor settings**. -- :::image type="content" source="media/prometheus-metrics-enable/aks-cluster-monitor-settings.png" lightbox="media/prometheus-metrics-enable/aks-cluster-monitor-settings.png" alt-text="Screenshot of button for monitor settings for an AKS cluster."::: --4. Click the checkbox for **Enable Prometheus metrics** and select your Azure Monitor workspace. -5. To send the collected metrics to Grafana, select a Grafana workspace. See [Create an Azure Managed Grafana instance](../../managed-grafan) for details on creating a Grafana workspace. -- :::image type="content" source="media/prometheus-metrics-enable/aks-cluster-monitor-settings-details.png" lightbox="media/prometheus-metrics-enable/aks-cluster-monitor-settings-details.png" alt-text="Screenshot of monitor settings for an AKS cluster."::: --6. Click **Configure** to complete the configuration. --See [Collect Prometheus metrics from AKS cluster (preview)](../essentials/prometheus-metrics-enable.md) for details on [verifying your deployment](../essentials/prometheus-metrics-enable.md#verify-deployment) and [limitations](../essentials/prometheus-metrics-enable.md#limitations-during-enablementdeployment) --#### From an existing cluster -This option enables Prometheus, Grafana, and Container insights on a cluster. --1. Open the clusters menu in the Azure portal and select **Insights**. -3. Select **Configure monitoring**. -4. Container insights is already enabled. Select the checkboxes for **Enable Prometheus metrics** and **Enable Grafana**. If you have existing Azure Monitor workspace and Grafana workspace, then they're selected for you. Click **Advanced settings** to select alternate workspaces or create new ones. -- :::image type="content" source="media/prometheus-metrics-enable/configure-container-insights.png" lightbox="media/prometheus-metrics-enable/configure-container-insights.png" alt-text="Screenshot that shows that show the dialog box to configure Container insights with Prometheus and Grafana."::: --5. Click **Configure** to save the configuration. ---### [CLI](#tab/cli) --#### Prerequisites --- The aks-preview extension must be uninstalled by using the command `az extension remove --name aks-preview`. For more information on how to uninstall a CLI extension, see [Use and manage extensions with the Azure CLI](/cli/azure/azure-cli-extensions-overview).-- Az CLI version of 2.49.0 or higher is required for this feature. Check the aks-preview version by using the `az version` command.--#### Install the metrics add-on --Use `az aks create` or `az aks update` with the `-enable-azure-monitor-metrics` option to install the metrics add-on. Depending on the Azure Monitor workspace and Grafana workspace you want to use, choose one of the following options: --- **Create a new default Azure Monitor workspace.**<br>-If no Azure Monitor workspace is specified, a default Azure Monitor workspace is created in a resource group with the name `DefaultRG-<cluster_region>` and is named `DefaultAzureMonitorWorkspace-<mapped_region>`. --- ```azurecli - az aks create/update --enable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> - ``` --- **Use an existing Azure Monitor workspace.**<br>-If the existing Azure Monitor workspace is already linked to one or more Grafana workspaces, data is available in that Grafana workspace. -- ```azurecli - az aks create/update --enable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> --azure-monitor-workspace-resource-id <workspace-name-resource-id> - ``` --- **Use an existing Azure Monitor workspace and link with an existing Grafana workspace.**<br>-This option creates a link between the Azure Monitor workspace and the Grafana workspace. -- ```azurecli - az aks create/update --enable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> --azure-monitor-workspace-resource-id <azure-monitor-workspace-name-resource-id> --grafana-resource-id <grafana-workspace-name-resource-id> - ``` --The output for each command looks similar to the following example: --```json -"azureMonitorProfile": { - "metrics": { - "enabled": true, - "kubeStateMetrics": { - "metricAnnotationsAllowList": "", - "metricLabelsAllowlist": "" - } - } -} -``` --#### Optional parameters -You can use the following optional parameters with the previous commands: --| Parameter | Description | -|:|:| -| `--ksm-metric-annotations-allow-list` | Comma-separated list of Kubernetes annotations keys used in the resource's kube_resource_annotations metric. For example, kube_pod_annotations is the annotations metric for the pods resource. By default, this metric contains only name and namespace labels. To include more annotations, provide a list of resource names in their plural form and Kubernetes annotation keys that you want to allow for them. A single `*` can be provided for each resource to allow any annotations, but this has severe performance implications. For example, `pods=[kubernetes.io/team,...],namespaces=[kubernetes.io/team],...`. | -| `--ksm-metric-labels-allow-list` | Comma-separated list of more Kubernetes label keys that is used in the resource's kube_resource_labels metric kube_resource_labels metric. For example, kube_pod_labels is the labels metric for the pods resource. By default this metric contains only name and namespace labels. To include more labels, provide a list of resource names in their plural form and Kubernetes label keys that you want to allow for them A single `*` can be provided for each resource to allow any labels, but i this has severe performance implications. For example, `pods=[app],namespaces=[k8s-label-1,k8s-label-n,...],...`. | -| `--enable-windows-recording-rules` | lets you enable the recording rule groups required for proper functioning of the Windows dashboards. | --**Use annotations and labels.** --```azurecli -az aks create/update --enable-azure-monitor-metrics -n <cluster-name> -g <cluster-resource-group> --ksm-metric-labels-allow-list "namespaces=[k8s-label-1,k8s-label-n]" --ksm-metric-annotations-allow-list "pods=[k8s-annotation-1,k8s-annotation-n]" -``` --The output is similar to the following example: --```json - "azureMonitorProfile": { - "metrics": { - "enabled": true, - "kubeStateMetrics": { - "metricAnnotationsAllowList": "pods=[k8s-annotation-1,k8s-annotation-n]", - "metricLabelsAllowlist": "namespaces=[k8s-label-1,k8s-label-n]" - } - } - } -``` --## [Azure Resource Manager](#tab/resource-manager) --### Prerequisites --- If the Azure Managed Grafana instance is in a subscription other than the Azure Monitor workspace subscription, register the Azure Monitor workspace subscription with the `Microsoft.Dashboard` resource provider by following [this documentation](../../azure-resource-manager/management/resource-providers-and-types.md#register-resource-provider).-- The Azure Monitor workspace and Azure Managed Grafana instance must already be created.-- The template must be deployed in the same resource group as the Azure Managed Grafana instance.-- Users with the `User Access Administrator` role in the subscription of the AKS cluster can enable the `Monitoring Reader` role directly by deploying the template.--### Retrieve required values for Grafana resource --On the **Overview** page for the Azure Managed Grafana instance in the Azure portal, select **JSON view**. --If you're using an existing Azure Managed Grafana instance that's already linked to an Azure Monitor workspace, the list of already existing Grafana integrations is needed. Copy the value of the `azureMonitorWorkspaceIntegrations` field. If it doesn't exist, then the instance hasn't been linked with any Azure Monitor workspace. --```json -"properties": { - "grafanaIntegrations": { - "azureMonitorWorkspaceIntegrations": [ - { - "azureMonitorWorkspaceResourceId": "full_resource_id_1" - }, - { - "azureMonitorWorkspaceResourceId": "full_resource_id_2" - } - ] - } -} -``` --### Download and edit the template and the parameter file --1. Download the template at [https://aka.ms/azureprometheus-enable-arm-template](https://aka.ms/azureprometheus-enable-arm-template) and save it as **existingClusterOnboarding.json**. -1. Download the parameter file at [https://aka.ms/azureprometheus-enable-arm-template-parameterss](https://aka.ms/azureprometheus-enable-arm-template-parameters) and save it as **existingClusterParam.json**. -1. Edit the values in the parameter file. -- | Parameter | Value | - |:|:| - | `azureMonitorWorkspaceResourceId` | Resource ID for the Azure Monitor workspace. Retrieve from the **JSON view** on the **Overview** page for the Azure Monitor workspace. | - | `azureMonitorWorkspaceLocation` | Location of the Azure Monitor workspace. Retrieve from the **JSON view** on the **Overview** page for the Azure Monitor workspace. | - | `clusterResourceId` | Resource ID for the AKS cluster. Retrieve from the **JSON view** on the **Overview** page for the cluster. | - | `clusterLocation` | Location of the AKS cluster. Retrieve from the **JSON view** on the **Overview** page for the cluster. | - | `metricLabelsAllowlist` | Comma-separated list of Kubernetes labels keys to be used in the resource's labels metric. | - | `metricAnnotationsAllowList` | Comma-separated list of more Kubernetes label keys to be used in the resource's annotations metric. | - | `grafanaResourceId` | Resource ID for the managed Grafana instance. Retrieve from the **JSON view** on the **Overview** page for the Grafana instance. | - | `grafanaLocation` | Location for the managed Grafana instance. Retrieve from the **JSON view** on the **Overview** page for the Grafana instance. | - | `grafanaSku` | SKU for the managed Grafana instance. Retrieve from the **JSON view** on the **Overview** page for the Grafana instance. Use the **sku.name**. | --1. Open the template file and update the `grafanaIntegrations` property at the end of the file with the values that you retrieved from the Grafana instance. The following example is similar: -- ```json - { - "type": "Microsoft.Dashboard/grafana", - "apiVersion": "2022-08-01", - "name": "[split(parameters('grafanaResourceId'),'/')[8]]", - "sku": { - "name": "[parameters('grafanaSku')]" - }, - "location": "[parameters('grafanaLocation')]", - "properties": { - "grafanaIntegrations": { - "azureMonitorWorkspaceIntegrations": [ - { - "azureMonitorWorkspaceResourceId": "full_resource_id_1" - }, - { - "azureMonitorWorkspaceResourceId": "full_resource_id_2" - }, - { - "azureMonitorWorkspaceResourceId": "[parameters('azureMonitorWorkspaceResourceId')]" - } - ] - } - } - ``` --In this JSON, `full_resource_id_1` and `full_resource_id_2` were already in the Azure Managed Grafana resource JSON. They're added here to the Azure Resource Manager template (ARM template). If you have no existing Grafana integrations, don't include these entries for `full_resource_id_1` and `full_resource_id_2`. --The final `azureMonitorWorkspaceResourceId` entry is already in the template and is used to link to the Azure Monitor workspace resource ID provided in the parameters file. --## [Bicep](#tab/bicep) --### Prerequisites --- The Azure Monitor workspace and Azure Managed Grafana instance must already be created.-- The template needs to be deployed in the same resource group as the Azure Managed Grafana instance.-- Users with the `User Access Administrator` role in the subscription of the AKS cluster can enable the `Monitoring Reader` role directly by deploying the template.--### Limitation with Bicep deployment -Currently in Bicep, there's no way to explicitly scope the `Monitoring Reader` role assignment on a string parameter "resource ID" for an Azure Monitor workspace (like in an ARM template). Bicep expects a value of type `resource | tenant`. There also is no REST API [spec](https://github.com/Azure/azure-rest-api-specs) for an Azure Monitor workspace. --Therefore, the default scoping for the `Monitoring Reader` role is on the resource group. The role is applied on the same Azure Monitor workspace (by inheritance), which is the expected behavior. After you deploy this Bicep template, the Grafana instance is given `Monitoring Reader` permissions for all the Azure Monitor workspaces in that resource group. --### Retrieve required values for a Grafana resource --On the **Overview** page for the Azure Managed Grafana instance in the Azure portal, select **JSON view**. --If you're using an existing Azure Managed Grafana instance that's already linked to an Azure Monitor workspace, the list of already existing Grafana integrations is needed. Copy the value of the `azureMonitorWorkspaceIntegrations` field. If it doesn't exist, then the instance hasn't been linked with any Azure Monitor workspace. --```json -"properties": { - "grafanaIntegrations": { - "azureMonitorWorkspaceIntegrations": [ - { - "azureMonitorWorkspaceResourceId": "full_resource_id_1" - }, - { - "azureMonitorWorkspaceResourceId": "full_resource_id_2" - } - ] - } -} -``` --### Download and edit templates and the parameter file --1. Download the [main Bicep template](https://aka.ms/azureprometheus-enable-bicep-template). Save it as **FullAzureMonitorMetricsProfile.bicep**. -2. Download the [parameter file](https://aka.ms/azureprometheus-enable-bicep-template-parameters) and save it as **FullAzureMonitorMetricsProfileParameters.json** in the same directory as the main Bicep template. -3. Download the [nested_azuremonitormetrics_dcra_clusterResourceId.bicep](https://aka.ms/nested_azuremonitormetrics_dcra_clusterResourceId) and [nested_azuremonitormetrics_profile_clusterResourceId.bicep](https://aka.ms/nested_azuremonitormetrics_profile_clusterResourceId) files into the same directory as the main Bicep template. -4. Edit the values in the parameter file. -5. The main Bicep template creates all the required resources. It uses two modules for creating the Data Collection Rule Associations (DCRA) and Azure Monitor metrics profile resources from the other two Bicep files. -- | Parameter | Value | - |:|:| - | `azureMonitorWorkspaceResourceId` | Resource ID for the Azure Monitor workspace. Retrieve from the **JSON view** on the **Overview** page for the Azure Monitor workspace. | - | `azureMonitorWorkspaceLocation` | Location of the Azure Monitor workspace. Retrieve from the **JSON view** on the **Overview** page for the Azure Monitor workspace. | - | `clusterResourceId` | Resource ID for the AKS cluster. Retrieve from the **JSON view** on the **Overview** page for the cluster. | - | `clusterLocation` | Location of the AKS cluster. Retrieve from the **JSON view** on the **Overview** page for the cluster. | - | `metricLabelsAllowlist` | Comma-separated list of Kubernetes labels keys used in the resource's labels metric. | - | `metricAnnotationsAllowList` | Comma-separated list of more Kubernetes label keys used in the resource's annotations metric. | - | `grafanaResourceId` | Resource ID for the managed Grafana instance. Retrieve from the **JSON view** on the **Overview** page for the Grafana instance. | - | `grafanaLocation` | Location for the managed Grafana instance. Retrieve from the **JSON view** on the **Overview** page for the Grafana instance. | - | `grafanaSku` | SKU for the managed Grafana instance. Retrieve from the **JSON view** on the **Overview** page for the Grafana instance. Use the **sku.name**. | --1. Open the template file and update the `grafanaIntegrations` property at the end of the file with the values that you retrieved from the Grafana instance. The following example is similar: -- ```json - { - "type": "Microsoft.Dashboard/grafana", - "apiVersion": "2022-08-01", - "name": "[split(parameters('grafanaResourceId'),'/')[8]]", - "sku": { - "name": "[parameters('grafanaSku')]" - }, - "location": "[parameters('grafanaLocation')]", - "properties": { - "grafanaIntegrations": { - "azureMonitorWorkspaceIntegrations": [ - { - "azureMonitorWorkspaceResourceId": "full_resource_id_1" - }, - { - "azureMonitorWorkspaceResourceId": "full_resource_id_2" - }, - { - "azureMonitorWorkspaceResourceId": "[parameters('azureMonitorWorkspaceResourceId')]" - } - ] - } - } - ``` --In this JSON, `full_resource_id_1` and `full_resource_id_2` were already in the Azure Managed Grafana resource JSON. They're added here to the ARM template. If you have no existing Grafana integrations, don't include these entries for `full_resource_id_1` and `full_resource_id_2`. --The final `azureMonitorWorkspaceResourceId` entry is already in the template and is used to link to the Azure Monitor workspace resource ID provided in the parameters file. --## [Terraform](#tab/terraform) --### Prerequisites --- If the Azure Managed Grafana instance is in a subscription other than the Azure Monitor Workspaces subscription, register the Azure Monitor Workspace subscription with the `Microsoft.Dashboard` resource provider by following [this documentation](../../azure-resource-manager/management/resource-providers-and-types.md#register-resource-provider).-- The Azure Monitor workspace and Azure Managed Grafana workspace must already be created.-- The template needs to be deployed in the same resource group as the Azure Managed Grafana workspace.-- Users with the User Access Administrator role in the subscription of the AKS cluster can enable the Monitoring Reader role directly by deploying the template.--### Retrieve required values for a Grafana resource --On the **Overview** page for the Azure Managed Grafana instance in the Azure portal, select **JSON view**. --If you're using an existing Azure Managed Grafana instance that's already linked to an Azure Monitor workspace, you need the list of Grafana integrations. Copy the value of the `azureMonitorWorkspaceIntegrations` field. If it doesn't exist, the instance hasn't been linked with any Azure Monitor workspace. Update the azure_monitor_workspace_integrations block(shown here) in main.tf with the list of grafana integrations. --```.tf - azure_monitor_workspace_integrations { - resource_id = var.monitor_workspace_id[var.monitor_workspace_id1, var.monitor_workspace_id2] - } -``` --### Download and edit the templates --If you're deploying a new AKS cluster using Terraform with managed Prometheus addon enabled, follow these steps: --1. Download all files under [AddonTerraformTemplate](https://aka.ms/AAkm357). -2. Edit the variables in variables.tf file with the correct parameter values. -3. Run `terraform init -upgrade` to initialize the Terraform deployment. -4. Run `terraform plan -out main.tfplan` to initialize the Terraform deployment. -5. Run `terraform apply main.tfplan` to apply the execution plan to your cloud infrastructure. ---Note: Pass the variables for `annotations_allowed` and `labels_allowed` keys in main.tf only when those values exist. These are optional blocks. --> [!NOTE] -> Edit the main.tf file appropriately before running the terraform template. Add in any existing azure_monitor_workspace_integrations values to the grafana resource before running the template. Else, older values gets deleted and replaced with what is there in the template during deployment. Users with 'User Access Administrator' role in the subscription of the AKS cluster can enable 'Monitoring Reader' role directly by deploying the template. Edit the grafanaSku parameter if you're using a nonstandard SKU and finally run this template in the Grafana Resource's resource group. --## [Azure Policy](#tab/azurepolicy) --### Prerequisites --- The Azure Monitor workspace and Azure Managed Grafana instance must already be created.--### Download Azure Policy rules and parameters and deploy --1. Download the main [Azure Policy rules template](https://aka.ms/AddonPolicyMetricsProfile). Save it as **AddonPolicyMetricsProfile.rules.json**. -1. Download the [parameter file](https://aka.ms/AddonPolicyMetricsProfile.parameters). Save it as **AddonPolicyMetricsProfile.parameters.json** in the same directory as the rules template. -1. Create the policy definition using the following command: -- `az policy definition create --name "(Preview) Prometheus Metrics addon" --display-name "(Preview) Prometheus Metrics addon" --mode Indexed --metadata version=1.0.0 category=Kubernetes --rules AddonPolicyMetricsProfile.rules.json --params AddonPolicyMetricsProfile.parameters.json` --1. After you create the policy definition, in the Azure portal, select **Policy** > **Definitions**. Select the policy definition you created. -1. Select **Assign**, go to the **Parameters** tab, and fill in the details. Select **Review + Create**. -1. After the policy is assigned to the subscription, whenever you create a new cluster without Prometheus enabled, the policy will run and deploy to enable Prometheus monitoring. If you want to apply the policy to an existing AKS cluster, create a **Remediation task** for that AKS cluster resource after you go to the **Policy Assignment**. -1. Now you should see metrics flowing in the existing Azure Managed Grafana instance, which is linked with the corresponding Azure Monitor workspace. --Afterwards, if you create a new Managed Grafana instance, you can link it with the corresponding Azure Monitor workspace from the **Linked Grafana Workspaces** tab of the relevant **Azure Monitor Workspace** page. The `Monitoring Reader` role must be assigned to the managed identity of the Managed Grafana instance with the scope as the Azure Monitor workspace, so that Grafana has access to query the metrics. Use the following instructions to do so: --1. On the **Overview** page for the Azure Managed Grafana instance in the Azure portal, select **JSON view**. --1. Copy the value of the `principalId` field for the `SystemAssigned` identity. -- ```json - "identity": { - "principalId": "00000000-0000-0000-0000-000000000000", - "tenantId": "00000000-0000-0000-0000-000000000000", - "type": "SystemAssigned" - }, - ``` -1. On the **Access control (IAM)** page for the Azure Managed Grafana instance in the Azure portal, select **Add** > **Add role assignment**. -1. Select `Monitoring Reader`. -1. Select **Managed identity** > **Select members**. -1. Select the **system-assigned managed identity** with the `principalId` from the Grafana resource. -1. Choose **Select** > **Review+assign**. --### Deploy the template --Deploy the template with the parameter file by using any valid method for deploying ARM templates. For examples of different methods, see [Deploy the sample templates](../resource-manager-samples.md#deploy-the-sample-templates). --### Limitations during enablement/deployment --- Ensure that you update the `kube-state metrics` annotations and labels list with proper formatting. There's a limitation in the ARM template deployments that require exact values in the `kube-state` metrics pods. If the Kubernetes pod has any issues with malformed parameters and isn't running, the feature might not run as expected.-- A data collection rule and data collection endpoint are created with the name `MSProm-\<short-cluster-region\>-\<cluster-name\>`. Currently, these names can't be modified.-- You must get the existing Azure Monitor workspace integrations for a Grafana instance and update the ARM template with it. Otherwise, the ARM deployment gets over-written, which removes existing integrations.---## Enable Windows metrics collection (preview) --> [!NOTE] -> There is no CPU/Memory limit in windows-exporter-daemonset.yaml so it may over-provision the Windows nodes -> For more details see [Resource reservation](https://kubernetes.io/docs/concepts/configuration/windows-resource-management/#resource-reservation) -> -> As you deploy workloads, set resource memory and CPU limits on containers. This also subtracts from NodeAllocatable and helps the cluster-wide scheduler in determining which pods to place on which nodes. -> Scheduling pods without limits may over-provision the Windows nodes and in extreme cases can cause the nodes to become unhealthy. ---As of version 6.4.0-main-02-22-2023-3ee44b9e of the Managed Prometheus addon container (prometheus_collector), Windows metric collection has been enabled for the AKS clusters. Onboarding to the Azure Monitor Metrics add-on enables the Windows DaemonSet pods to start running on your node pools. Both Windows Server 2019 and Windows Server 2022 are supported. Follow these steps to enable the pods to collect metrics from your Windows node pools. --1. Manually install windows-exporter on AKS nodes to access Windows metrics. - Enable the following collectors: -- * `[defaults]` - * `container` - * `memory` - * `process` - * `cpu_info` -- Deploy the [windows-exporter-daemonset YAML](https://github.com/prometheus-community/windows_exporter/blob/master/kubernetes/windows-exporter-daemonset.yaml) file: -- ``` - kubectl apply -f windows-exporter-daemonset.yaml - ``` --1. Apply the [ama-metrics-settings-configmap](https://github.com/Azure/prometheus-collector/blob/main/otelcollector/configmaps/ama-metrics-settings-configmap.yaml) to your cluster. Set the `windowsexporter` and `windowskubeproxy` Booleans to `true`. For more information, see [Metrics add-on settings configmap](./prometheus-metrics-scrape-configuration.md#metrics-add-on-settings-configmap). -1. Enable the recording rules that are required for the out-of-the-box dashboards: -- * If onboarding using the CLI, include the option `--enable-windows-recording-rules`. - * If onboarding using an ARM template, Bicep, or Azure Policy, set `enableWindowsRecordingRules` to `true` in the parameters file. --## Verify deployment --1. Run the following command to verify that the DaemonSet was deployed properly on the Linux node pools: -- ``` - kubectl get ds ama-metrics-node --namespace=kube-system - ``` -- The number of pods should be equal to the number of Linux nodes on the cluster. The output should resemble the following example: -- ``` - User@aksuser:~$ kubectl get ds ama-metrics-node --namespace=kube-system - NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE - ama-metrics-node 1 1 1 1 1 <none> 10h - ``` --1. Run the following command to verify that the DaemonSet was deployed properly on the Windows node pools: -- ``` - kubectl get ds ama-metrics-win-node --namespace=kube-system - ``` -- The number of pods should be equal to the number of Windows nodes on the cluster. The output should resemble the following example: -- ``` - User@aksuser:~$ kubectl get ds ama-metrics-node --namespace=kube-system - NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE - ama-metrics-win-node 3 3 3 3 3 <none> 10h - ``` --1. Run the following command to verify that the two ReplicaSets were deployed properly: -- ``` - kubectl get rs --namespace=kube-system - ``` -- The output should resemble the following example: -- ``` - User@aksuser:~$kubectl get rs --namespace=kube-system - NAME DESIRED CURRENT READY AGE - ama-metrics-5c974985b8 1 1 1 11h - ama-metrics-ksm-5fcf8dffcd 1 1 1 11h - ``` -## Artifacts/Resources provisioned/created as a result of metrics addon enablement for an AKS cluster --When you enable metrics addon, the following resources are provisioned: --| Resource Name | Resource Type | Resource Group | Region/Location | Description | - |:|:|:|:|:| - | `MSPROM-<aksclusterregion>-<clustername>` | **Data Collection Rule** | Same Resource group as AKS cluster resource | Same region as Azure Monitor Workspace | This data collection rule is for prometheus metrics collection by metrics addon, which has the chosen Azure monitor workspace as destination, and also it is associated to the AKS cluster resource | - | `MSPROM-<aksclusterregion>-<clustername>` | **Data Collection endpoint** | Same Resource group as AKS cluster resource | Same region as Azure Monitor Workspace | This data collection endpoint is used by the above data collection rule for ingesting Prometheus metrics from the metrics addon| - -When you create a new Azure Monitor workspace, the following additional resources are created as part of it --| Resource Name | Resource Type | Resource Group | Region/Location | Description | - |:|:|:|:|:| - | `<azuremonitor-workspace-name>` | **System Data Collection Rule** | MA_\<azuremonitor-workspace-name>_\<azuremonitor-workspace-region>_managed | Same region as Azure Monitor Workspace | This is **system** data collection rule that customers can use when they use OSS Prometheus server to Remote Write to Azure Monitor Workspace | - | `<azuremonitor-workspace-name>` | **System Data Collection endpoint** | MA_\<azuremonitor-workspace-name>_\<azuremonitor-workspace-region>_managed | Same region as Azure Monitor Workspace | This is **system** data collection endpoint that customers can use when they use OSS Prometheus server to Remote Write to Azure Monitor Workspace | - --## HTTP Proxy --Azure Monitor metrics addon supports HTTP Proxy and uses the same settings as the HTTP Proxy settings for the AKS cluster configured with [these instructions](../../../articles/aks/http-proxy.md). --## Network firewall requirements --**Azure public cloud** --The following table lists the firewall configuration required for Azure monitor Prometheus metrics ingestion for Azure Public cloud. All network traffic from the agent is outbound to Azure Monitor. --|Agent resource| Purpose | Port | -|--||| -| `global.handler.control.monitor.azure.com` | Access control service/ Azure Monitor control plane service | 443 | -| `*.ingest.monitor.azure.com` | Azure monitor managed service for Prometheus - metrics ingestion endpoint (DCE) | 443 | -| `*.handler.control.monitor.azure.com` | For querying data collection rules | 443 | --**Azure US Government cloud** --The following table lists the firewall configuration required for Azure monitor Prometheus metrics ingestion for Azure US Government cloud. All network traffic from the agent is outbound to Azure Monitor. --|Agent resource| Purpose | Port | -|--||| -| `global.handler.control.monitor.azure.us` | Access control service/ Azure Monitor control plane service | 443 | -| `*.ingest.monitor.azure.us` | Azure monitor managed service for Prometheus - metrics ingestion endpoint (DCE) | 443 | -| `*.handler.control.monitor.azure.us` | For querying data collection rules | 443 | --## Uninstall the metrics add-on --To uninstall the metrics add-on, see [Disable Prometheus metrics collection on an AKS cluster.](./prometheus-metrics-disable.md) --## Supported regions --The list of regions Azure Monitor Metrics and Azure Monitor Workspace is supported in can be found [here](https://aka.ms/ama-metrics-supported-regions) under the Managed Prometheus tag. --## Frequently asked questions --This section provides answers to common questions. --### Does enabling managed service for Prometheus on my Azure Kubernetes Service cluster also enable Container insights? --You have options for how you can collect your Prometheus metrics. If you use the Azure portal and enable Prometheus metrics collection and install the Azure Kubernetes Service (AKS) add-on from the Azure Monitor workspace UX, it won't enable Container insights and collection of log data. When you go to the Insights page on your AKS cluster, you're prompted to enable Container insights to collect log data.<br> - -If you use the Azure portal and enable Prometheus metrics collection and install the AKS add-on from the Insights page of your AKS cluster, it enables log collection into a Log Analytics workspace. and Prometheus metrics collection into an Azure Monitor workspace. --## Next steps --- [See the default configuration for Prometheus metrics](./prometheus-metrics-scrape-default.md)-- [Customize Prometheus metric scraping for the cluster](./prometheus-metrics-scrape-configuration.md)-- [Use Azure Monitor managed service for Prometheus as the data source for Grafana](../essentials/prometheus-grafana.md)-- [Configure self-hosted Grafana to use Azure Monitor managed service for Prometheus](../essentials/prometheus-self-managed-grafana-azure-active-directory.md) |
azure-monitor | Prometheus Metrics From Arc Enabled Cluster | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-metrics-from-arc-enabled-cluster.md | - Title: Collect Prometheus metrics from an Arc-enabled Kubernetes cluster (preview) -description: How to configure your Azure Arc-enabled Kubernetes cluster (preview) to send data to Azure Monitor managed service for Prometheus. ---- Previously updated : 05/07/2023---# Collect Prometheus metrics from an Arc-enabled Kubernetes cluster (preview) --This article describes how to configure your Azure Arc-enabled Kubernetes cluster (preview) to send data to Azure Monitor managed service for Prometheus. When you configure your Azure Arc-enabled Kubernetes cluster to send data to Azure Monitor managed service for Prometheus, a containerized version of the Azure Monitor agent is installed with a metrics extension. You then specify the Azure Monitor workspace where the data should be sent. --> [!NOTE] -> The process described here doesn't enable [Container insights](../containers/container-insights-overview.md) on the cluster even though the Azure Monitor agent installed in this process is the same agent used by Container insights. -> For different methods to enable Container insights on your cluster, see [Enable Container insights](../containers/container-insights-onboard.md). For details on adding Prometheus collection to a cluster that already has Container insights enabled, see [Collect Prometheus metrics with Container insights](../containers/container-insights-prometheus.md). --## Supported configurations --The following configurations are supported: --+ Azure Monitor Managed Prometheus supports monitoring Azure Arc-enabled Kubernetes. For more information, see [Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md). -+ Docker -+ Moby -+ CRI compatible container runtimes such CRI-O --The following configurations are not supported: --+ Windows -+ Azure Red Hat OpenShift 4 --## Prerequisites --+ Prerequisites listed in [Deploy and manage Azure Arc-enabled Kubernetes cluster extensions](../../azure-arc/kubernetes/extensions.md#prerequisites) -+ An Azure Monitor workspace. To create new workspace, see [Manage an Azure Monitor workspace ](../essentials/azure-monitor-workspace-manage.md). -+ The cluster must use [managed identity authentication](../../aks/use-managed-identity.md). -+ The following resource providers must be registered in the subscription of the Arc-enabled Kubernetes cluster and the Azure Monitor workspace: - + Microsoft.Kubernetes - + Microsoft.Insights - + Microsoft.AlertsManagement -+ The following endpoints must be enabled for outbound access in addition to the [Azure Arc-enabled Kubernetes network requirements](../../azure-arc/kubernetes/network-requirements.md?tabs=azure-cloud): - **Azure public cloud** -- |Endpoint|Port| - ||--| - |*.ods.opinsights.azure.com |443 | - |*.oms.opinsights.azure.com |443 | - |dc.services.visualstudio.com |443 | - |*.monitoring.azure.com |443 | - |login.microsoftonline.com |443 | - |global.handler.control.monitor.azure.com |443 | - | \<cluster-region-name\>.handler.control.monitor.azure.com |443 | --## Create an extension instance --### [Portal](#tab/portal) --### Onboard from Azure Monitor workspace --1. Open the **Azure Monitor workspaces** menu in the Azure portal and select your cluster. --1. Select **Managed Prometheus** to display a list of AKS and Arc clusters. -1. Select **Configure** for the cluster you want to enable. ---### Onboard from Container insights --1. In the Azure portal, select the Azure Arc-enabled Kubernetes cluster that you wish to monitor. --1. From the resource pane on the left, select **Insights** under the **Monitoring** section. -1. On the onboarding page, select **Configure monitoring**. -1. On the **Configure Container insights** page, select the **Enable Prometheus metrics** checkbox. -1. Select **Configure**. ---### [CLI](#tab/cli) --### Prerequisites --+ The k8s-extension extension must be installed. Install the extension using the command `az extension add --name k8s-extension`. -+ The k8s-extension version 1.4.1 or higher is required. Check the k8s-extension version by using the `az version` command. --### Create an extension with default values --+ A default Azure Monitor workspace is created in the DefaultRG-<cluster_region> following the format `DefaultAzureMonitorWorkspace-<mapped_region>`. -+ Auto-upgrade is enabled for the extension. --```azurecli -az k8s-extension create \ name azuremonitor-metrics \cluster-name <cluster-name> \resource-group <resource-group> \cluster-type connectedClusters \extension-type Microsoft.AzureMonitor.Containers.Metrics -``` --### Create an extension with an existing Azure Monitor workspace --If the Azure Monitor workspace is already linked to one or more Grafana workspaces, the data is available in Grafana. --```azurecli -az k8s-extension create\ name azuremonitor-metrics\cluster-name <cluster-name>\resource-group <resource-group>\cluster-type connectedClusters\extension-type Microsoft.AzureMonitor.Containers.Metrics\configuration-settings azure-monitor-workspace-resource-id=<workspace-name-resource-id> -``` --### Create an extension with an existing Azure Monitor workspace and link with an existing Grafana workspace --This option creates a link between the Azure Monitor workspace and the Grafana workspace. --```azurecli -az k8s-extension create\ name azuremonitor-metrics\cluster-name <cluster-name>\resource-group <resource-group>\cluster-type connectedClusters\extension-type Microsoft.AzureMonitor.Containers.Metrics\configuration-settings azure-monitor-workspace-resource-id=<workspace-name-resource-id> \-grafana-resource-id=<grafana-workspace-name-resource-id> -``` --### Create an extension with optional parameters --You can use the following optional parameters with the previous commands: --`--configurationsettings.AzureMonitorMetrics.KubeStateMetrics.MetricsLabelsAllowlist` is a comma-separated list of Kubernetes label keys that will be used in the resource' labels metric. By default the metric contains only name and namespace labels. To include additional labels, provide a list of resource names in their plural form and Kubernetes label keys you would like to allow for them. For example, `=namespaces=[kubernetes.io/team,...],pods=[kubernetes.io/team],...` --`--configurationSettings.AzureMonitorMetrics.KubeStateMetrics.MetricAnnotationsAllowList` is a comma-separated list of Kubernetes annotations keys that will be used in the resource' labels metric. By default the metric contains only name and namespace labels. To include additional annotations, provide a list of resource names in their plural form and Kubernetes annotation keys you would like to allow for them. For example, `=namespaces=[kubernetes.io/team,...],pods=[kubernetes.io/team],...`. --> [!NOTE] -> A single `*`, for example `'=pods=[*]'` can be provided per resource to allow any labels, however, this has severe performance implications. ---```azurecli -az k8s-extension create\ name azuremonitor-metrics\cluster-name <cluster-name>\resource-group <resource-group>\cluster-type connectedClusters\extension-type Microsoft.AzureMonitor.Containers.Metrics\configuration-settings azure-monitor-workspace-resource-id=<workspace-name-resource-id> \-grafana-resource-id=<grafana-workspace-name-resource-id> \ -AzureMonitorMetrics.KubeStateMetrics.MetricAnnotationsAllowList="pods=[k8s-annotation-1,k8s-annotation-n]" \ -AzureMonitorMetrics.KubeStateMetrics.MetricsLabelsAllowlist "namespaces=[k8s-label-1,k8s-label-n]" -``` --### [Resource Manager](#tab/resource-manager) --### Prerequisites --+ If the Azure Managed Grafana instance is in a subscription other than the Azure Monitor Workspaces subscription, register the Azure Monitor Workspace subscription with the `Microsoft.Dashboard` resource provider by following the steps in the [Register resource provider](../../azure-resource-manager/management/resource-providers-and-types.md#register-resource-provider) section of the Azure resource providers and types article. --+ The Azure Monitor workspace and Azure Managed Grafana workspace must already exist. -+ The template must be deployed in the same resource group as the Azure Managed Grafana workspace. -+ Users with the User Access Administrator role in the subscription of the AKS cluster can enable the Monitoring Data Reader role directly by deploying the template. --### Create an extension --1. Retrieve required values for the Grafana resource -- > [!NOTE] - > Azure Managed Grafana is not currently available in the Azure US Government cloud. -- On the Overview page for the Azure Managed Grafana instance in the Azure portal, select **JSON view**. -- If you're using an existing Azure Managed Grafana instance that's already linked to an Azure Monitor workspace, you need the list of already existing Grafana integrations. Copy the value of the `azureMonitorWorkspaceIntegrations` field. If the field doesn't exist, the instance hasn't been linked with any Azure Monitor workspace. -- ```json - "properties": { - "grafanaIntegrations": { - "azureMonitorWorkspaceIntegrations": [ - { - "azureMonitorWorkspaceResourceId": "full_resource_id_1" - }, - { - "azureMonitorWorkspaceResourceId": "full_resource_id_2" - } - ] - } - } - ``` --1. Download and edit the template and the parameter file --- 1. Download the template at https://aka.ms/azureprometheus-arc-arm-template and save it as *existingClusterOnboarding.json*. -- 1. Download the parameter file at https://aka.ms/azureprometheus-arc-arm-template-parameters and save it as *existingClusterParam.json*. --1. Edit the following fields' values in the parameter file. -- |Parameter|Value | - ||| - |`azureMonitorWorkspaceResourceId` |Resource ID for the Azure Monitor workspace. Retrieve from the **JSON view** on the Overview page for the Azure Monitor workspace. | - |`azureMonitorWorkspaceLocation`|Location of the Azure Monitor workspace. Retrieve from the JSON view on the Overview page for the Azure Monitor workspace. | - |`clusterResourceId` |Resource ID for the Arc cluster. Retrieve from the **JSON view** on the Overview page for the cluster. | - |`clusterLocation` |Location of the Arc cluster. Retrieve from the **JSON view** on the Overview page for the cluster. | - |`metricLabelsAllowlist` |Comma-separated list of Kubernetes labels keys to be used in the resource's labels metric.| - |`metricAnnotationsAllowList` |Comma-separated list of more Kubernetes label keys to be used in the resource's labels metric. | - |`grafanaResourceId` |Resource ID for the managed Grafana instance. Retrieve from the **JSON view** on the Overview page for the Grafana instance. | - |`grafanaLocation` |Location for the managed Grafana instance. Retrieve from the **JSON view** on the Overview page for the Grafana instance. | - |`grafanaSku` |SKU for the managed Grafana instance. Retrieve from the **JSON view** on the Overview page for the Grafana instance. Use the `sku.name`. | --1. Open the template file and update the `grafanaIntegrations` property at the end of the file with the values that you retrieved from the Grafana instance. For example: -- ```json - { - "type": "Microsoft.Dashboard/grafana", - "apiVersion": "2022-08-01", - "name": "[split(parameters('grafanaResourceId'),'/')[8]]", - "sku": { - "name": "[parameters('grafanaSku')]" - }, - "location": "[parameters('grafanaLocation')]", - "properties": { - "grafanaIntegrations": { - "azureMonitorWorkspaceIntegrations": [ - { - "azureMonitorWorkspaceResourceId": "full_resource_id_1" - }, - { - "azureMonitorWorkspaceResourceId": "full_resource_id_2" - }, - { - "azureMonitorWorkspaceResourceId": "[parameters ('azureMonitorWorkspaceResourceId')]" - } - ] - } - } - } - ``` -- In the example JSON above, `full_resource_id_1` and `full_resource_id_2` are already in the Azure Managed Grafana resource JSON. They're added here to the Azure Resource Manager template (ARM template). If you don't have any existing Grafana integrations, don't include these entries. -- The final `azureMonitorWorkspaceResourceId` entry is in the template by default and is used to link to the Azure Monitor workspace resource ID provided in the parameters file. --### Verify extension installation status --Once you have successfully created the Azure Monitor extension for your Azure Arc-enabled Kubernetes cluster, you can check the status of the installation using the Azure portal or CLI. Successful installations show the status as `Installed`. --#### Azure portal --1. In the Azure portal, select the Azure Arc-enabled Kubernetes cluster with the extension installation. --1. From the resource pane on the left, select the **Extensions** item under the **Setting**' section. --1. An extension with the name **azuremonitor-metrics** is listed, with the current status in the **Install status** column. --#### Azure CLI --Run the following command to show the latest status of the` Microsoft.AzureMonitor.Containers.Metrics` extension. --```azurecli -az k8s-extension show \ name azuremonitor-metrics \cluster-name <cluster-name> \resource-group <resource-group> \cluster-type connectedClusters -``` ---### Delete the extension instance --To delete the extension instance, use the following CLI command: --```azurecli -az k8s-extension delete --name azuremonitor-metrics -g <cluster_resource_group> -c<cluster_name> -t connectedClusters -``` --The command only deletes the extension instance. The Azure Monitor workspace and its data are not deleted. --## Disconnected clusters --If your cluster is disconnected from Azure for more than 48 hours, Azure Resource Graph won't have information about your cluster. As a result, your Azure Monitor Workspace may have incorrect information about your cluster state. --## Troubleshooting --For issues with the extension, see the [Troubleshooting Guide](./prometheus-metrics-troubleshoot.md). --## Next Steps --+ [Default Prometheus metrics configuration in Azure Monitor ](prometheus-metrics-scrape-default.md) -+ [Customize scraping of Prometheus metrics in Azure Monitor](prometheus-metrics-scrape-configuration.md) -+ [Use Azure Monitor managed service for Prometheus as data source for Grafana using managed system identity](../essentials/prometheus-grafana.md) -+ [Configure self-managed Grafana to use Azure Monitor managed service for Prometheus with Microsoft Entra ID](../essentials/prometheus-self-managed-grafana-azure-active-directory.md) |
azure-monitor | Prometheus Metrics Multiple Workspaces | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-metrics-multiple-workspaces.md | Routing metrics to more Azure Monitor workspaces can be done through the creatio ## Send same metrics to multiple Azure Monitor workspaces -You can create multiple Data Collection Rules that point to the same Data Collection Endpoint for metrics to be sent to additional Azure Monitor workspaces from the same Kubernetes cluster. In case you have a very high volume of metrics, a new Data Collection Endpoint can be created as well. Please refer to the service limits [document](../service-limits.md) regarding ingestion limits. Currently, this is only available through onboarding through Resource Manager templates. You can follow the [regular onboarding process](prometheus-metrics-enable.md) and then edit the same Resource Manager templates to add additional DCRs and DCEs (if applicable) for your additional Azure Monitor workspaces. You'll need to edit the template to add an additional parameters for every additional Azure Monitor workspace, add another DCR for every additional Azure Monitor workspace, add another DCE (if applicable), add the Monitor Reader Role for the new Azure Monitor workspace and add an additional Azure Monitor workspace integration for Grafana. +You can create multiple Data Collection Rules that point to the same Data Collection Endpoint for metrics to be sent to additional Azure Monitor workspaces from the same Kubernetes cluster. In case you have a very high volume of metrics, a new Data Collection Endpoint can be created as well. Please refer to the service limits [document](../service-limits.md) regarding ingestion limits. Currently, this is only available through onboarding through Resource Manager templates. You can follow the [regular onboarding process](kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) and then edit the same Resource Manager templates to add additional DCRs and DCEs (if applicable) for your additional Azure Monitor workspaces. You'll need to edit the template to add an additional parameters for every additional Azure Monitor workspace, add another DCR for every additional Azure Monitor workspace, add another DCE (if applicable), add the Monitor Reader Role for the new Azure Monitor workspace and add an additional Azure Monitor workspace integration for Grafana. - Add the following parameters: ```json scrape_configs: ## Next steps - [Learn more about Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md).-- [Collect Prometheus metrics from AKS cluster](prometheus-metrics-enable.md).+- [Collect Prometheus metrics from AKS cluster](kubernetes-monitoring-enable.md#enable-prometheus-and-grafana). |
azure-monitor | Prometheus Metrics Scrape Configuration Minimal | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-metrics-scrape-configuration-minimal.md | Title: Minimal Prometheus ingestion profile in Azure Monitor -description: Describes minimal ingestion profile in Azure Monitor managed service for Prometheus and how you can configure it collect more data. +description: Describes minimal ingestion profile in Azure Monitor managed service for Prometheus and how you can configure it to collect more data. - Previously updated : 09/28/2022 Last updated : 1/28/2023 |
azure-monitor | Prometheus Metrics Scrape Configuration | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-metrics-scrape-configuration.md | -This article provides instructions on customizing metrics scraping for a Kubernetes cluster with the [metrics addon](prometheus-metrics-enable.md) in Azure Monitor. +This article provides instructions on customizing metrics scraping for a Kubernetes cluster with the [metrics addon](kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) in Azure Monitor. ## Configmaps To further customize the default jobs to change properties like collection frequ ### Cluster alias The cluster label appended to every time series scraped uses the last part of the full AKS cluster's Azure Resource Manager resource ID. For example, if the resource ID is `/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rg-name/providers/Microsoft.ContainerService/managedClusters/myclustername`, the cluster label is `myclustername`. -To override the cluster label in the time series scraped, update the setting `cluster_alias` to any string under `prometheus-collector-settings` in the [configmap](https://aka.ms/azureprometheus-addon-settings-configmap) `ama-metrics-settings-configmap`. You can create this configmap if it doesn't exist in the cluster or you can edit the existing one if its already exists in your cluster. +To override the cluster label in the time series scraped, update the setting `cluster_alias` to any string under `prometheus-collector-settings` in the [configmap](https://aka.ms/azureprometheus-addon-settings-configmap) `ama-metrics-settings-configmap`. You can create this configmap if it doesn't exist in the cluster or you can edit the existing one if it already exists in your cluster. The new label also shows up in the cluster parameter dropdown in the Grafana dashboards instead of the default one. |
azure-monitor | Prometheus Metrics Scrape Default | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-metrics-scrape-default.md | Title: Default Prometheus metrics configuration in Azure Monitor description: This article lists the default targets, dashboards, and recording rules for Prometheus metrics in Azure Monitor. - Previously updated : 09/28/2022 Last updated : 11/28/2023 # Default Prometheus metrics configuration in Azure Monitor -This article lists the default targets, dashboards, and recording rules when you [configure Prometheus metrics to be scraped from an Azure Kubernetes Service (AKS) cluster](prometheus-metrics-enable.md) for any AKS cluster. +This article lists the default targets, dashboards, and recording rules when you [configure Prometheus metrics to be scraped from an Azure Kubernetes Service (AKS) cluster](kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) for any AKS cluster. ++## Minimal ingestion profile +`Minimal ingestion profile` is a setting that helps reduce ingestion volume of metrics, as only metrics used by default dashboards, default recording rules & default alerts are collected. For addon based collection, `Minimal ingestion profile` setting is enabled by default. You can modify collection to enable collecting more metrics, as specified below. ## Scrape frequency The default scrape frequency for all default targets and scrapes is 30 seconds. ## Targets scraped by default+Following targets are **enabled/ON** by default - meaning you don't have to provide any scrape job configuration for scraping these targets, as metrics addon will scrape these targets automatically by default - `cadvisor` (`job=cadvisor`) - `nodeexporter` (`job=node`) Two default jobs can be run for Windows that scrape metrics required for the das - `kube-proxy-windows` (`job=kube-proxy-windows`) > [!NOTE]-> This requires applying or updating the `ama-metrics-settings-configmap` configmap and installing `windows-exporter` on all Windows nodes. For more information, see the [enablement document](./prometheus-metrics-enable.md#enable-prometheus-metric-collection). +> This requires applying or updating the `ama-metrics-settings-configmap` configmap and installing `windows-exporter` on all Windows nodes. For more information, see the [enablement document](kubernetes-monitoring-enable.md#enable-prometheus-and-grafana). ## Metrics scraped for Windows |
azure-monitor | Prometheus Remote Write Active Directory | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-remote-write-active-directory.md | See [Azure Monitor managed service for Prometheus remote write](prometheus-remot ## Next steps -- [Collect Prometheus metrics from an AKS cluster](../containers/prometheus-metrics-enable.md)+- [Collect Prometheus metrics from an AKS cluster](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) - [Learn more about Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md). - [Remote-write in Azure Monitor Managed Service for Prometheus](prometheus-remote-write.md) - [Configure remote write for Azure Monitor managed service for Prometheus using managed identity authentication](./prometheus-remote-write-managed-identity.md) |
azure-monitor | Prometheus Remote Write Azure Ad Pod Identity | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-remote-write-azure-ad-pod-identity.md | To configure remote write for Azure Monitor managed service for Prometheus using ``` ## Next steps -- [Collect Prometheus metrics from an AKS cluster](../containers/prometheus-metrics-enable.md)+- [Collect Prometheus metrics from an AKS cluster](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) - [Learn more about Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md) - [Remote-write in Azure Monitor Managed Service for Prometheus](prometheus-remote-write.md) - [Remote-write in Azure Monitor Managed Service for Prometheus using Microsoft Entra ID](./prometheus-remote-write-active-directory.md) |
azure-monitor | Prometheus Remote Write Azure Workload Identity | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-remote-write-azure-workload-identity.md | Use the sample yaml below if you're using kube-prometheus-stack: ## Next steps -* [Collect Prometheus metrics from an AKS cluster](../containers/prometheus-metrics-enable.md) +* [Collect Prometheus metrics from an AKS cluster](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) * [Learn more about Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md) * [Remote-write in Azure Monitor Managed Service for Prometheus](prometheus-remote-write.md) * [Remote-write in Azure Monitor Managed Service for Prometheus using Microsoft Entra ID](./prometheus-remote-write-active-directory.md) |
azure-monitor | Prometheus Remote Write Managed Identity | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-remote-write-managed-identity.md | See [Azure Monitor managed service for Prometheus remote write](prometheus-remot ## Next steps -- [Collect Prometheus metrics from an AKS cluster](../containers/prometheus-metrics-enable.md)+- [Collect Prometheus metrics from an AKS cluster](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) - [Learn more about Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md) - [Remote-write in Azure Monitor Managed Service for Prometheus](prometheus-remote-write.md) - [Remote-write in Azure Monitor Managed Service for Prometheus using Microsoft Entra ID](./prometheus-remote-write-active-directory.md) |
azure-monitor | Prometheus Remote Write | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/containers/prometheus-remote-write.md | az monitor data-collection rule show --name "myCollectionRule" --resource-group ## Next steps - [Learn more about Azure Monitor managed service for Prometheus](../essentials/prometheus-metrics-overview.md).-- [Collect Prometheus metrics from an AKS cluster](../containers/prometheus-metrics-enable.md)+- [Collect Prometheus metrics from an AKS cluster](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) - [Remote-write in Azure Monitor Managed Service for Prometheus using Microsoft Entra ID](./prometheus-remote-write-active-directory.md) - [Configure remote write for Azure Monitor managed service for Prometheus using managed identity authentication](./prometheus-remote-write-managed-identity.md) - [Configure remote write for Azure Monitor managed service for Prometheus using Azure Workload Identity (preview)](./prometheus-remote-write-azure-workload-identity.md) |
azure-monitor | Cost Usage | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/cost-usage.md | Several other features don't have a direct cost, but you instead pay for the ing | Logs | Ingestion, retention, and export of data in [Log Analytics workspaces](logs/log-analytics-workspace-overview.md) and [legacy Application insights resources](app/convert-classic-resource.md). This will typically be the bulk of Azure Monitor charges for most customers. There is no charge for querying this data except in the case of [Basic Logs](logs/basic-logs-configure.md) or [Archived Logs](logs/data-retention-archive.md).<br><br>Charges for Logs can vary significantly on the configuration that you choose. See [Azure Monitor Logs pricing details](logs/cost-logs.md) for details on how charges for Logs data are calculated and the different pricing tiers available. | | Platform Logs | Processing of [diagnostic and auditing information](essentials/resource-logs.md) is charged for [certain services](essentials/resource-logs-categories.md#costs) when sent to destinations other than a Log Analytics workspace. There's no direct charge when this data is sent to a Log Analytics workspace, but there is a charge for the workspace data ingestion and collection. | | Metrics | There is no charge for [standard metrics](essentials/metrics-supported.md) collected from Azure resources. There is a cost for collecting [custom metrics](essentials/metrics-custom-overview.md) and for retrieving metrics from the [REST API](essentials/rest-api-walkthrough.md#retrieve-metric-values). |-| Prometheus Metrics | Pricing for [Azure Monitor managed service for Prometheus](essentials/prometheus-metrics-overview.md) is based on [data samples ingested](essentials/prometheus-metrics-enable.md) and [query samples processed](essentials/azure-monitor-workspace-manage.md#link-a-grafana-workspace). Data is retained for 18 months at no extra charge. | +| Prometheus Metrics | Pricing for [Azure Monitor managed service for Prometheus](essentials/prometheus-metrics-overview.md) is based on [data samples ingested](containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) and [query samples processed](essentials/azure-monitor-workspace-manage.md#link-a-grafana-workspace). Data is retained for 18 months at no extra charge. | | Alerts | Alerts are charged based on the type and number of [signals](alerts/alerts-overview.md) used by the alert rule, its frequency, and the type of [notification](alerts/action-groups.md) used in response. For [log alerts](alerts/alerts-unified-log.md) configured for [at scale monitoring](alerts/alerts-unified-log.md#split-by-alert-dimensions), the cost will also depend on the number of time series created by the dimensions resulting from your query. | | Web tests | There is a cost for [standard web tests](app/availability-standard-tests.md) and [multi-step web tests](app/availability-multistep.md) in Application Insights. Multi-step web tests have been deprecated. |
azure-monitor | Azure Monitor Workspace Manage | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/essentials/azure-monitor-workspace-manage.md | resource workspace 'microsoft.monitor/accounts@2021-06-03-preview' = { When you create an Azure Monitor workspace, a new resource group is created. The resource group name has the following format: `MA_<azure-monitor-workspace-name>_<location>_managed`, where the tokenized elements are lowercased. The resource group contains both a data collection endpoint and a data collection rule with the same name as the workspace. The resource group and its resources are automatically deleted when you delete the workspace. -To connect your Azure Monitor managed service for Prometheus to your Azure Monitor workspace, see [Collect Prometheus metrics from AKS cluster](./prometheus-metrics-enable.md) +To connect your Azure Monitor managed service for Prometheus to your Azure Monitor workspace, see [Collect Prometheus metrics from AKS cluster](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) ## Delete an Azure Monitor workspace Output ### [Resource Manager](#tab/resource-manager) -To set up an Azure monitor workspace as a data source for Grafana using a Resource Manager template, see [Collect Prometheus metrics from AKS cluster](prometheus-metrics-enable.md?tabs=resource-manager#enable-prometheus-metric-collection) +To set up an Azure monitor workspace as a data source for Grafana using a Resource Manager template, see [Collect Prometheus metrics from AKS cluster](../containers/kubernetes-monitoring-enable.md?tabs=arm#enable-prometheus-and-grafana) Yes. When you use managed service for Prometheus, you can create your Azure Moni ## Next steps-- [Link a Grafana instance to your Azure Monitor workspace](./prometheus-metrics-enable.md#enable-prometheus-metric-collection) - Learn more about the [Azure Monitor data platform](../data-platform.md). - [Azure Monitor workspace Overview](./azure-monitor-workspace-overview.md) |
azure-monitor | Data Collection Rule Best Practices | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/essentials/data-collection-rule-best-practices.md | Title: Best practices for data collection rule creation and management in Azure Monitor description: Details on the best practices to be followed to correctly create and maintain data collection rule in Azure Monitor. Previously updated : 12/14/2022 Last updated : 01/08/2024 |
azure-monitor | Data Collection Rule Create Edit | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/essentials/data-collection-rule-create-edit.md | The following table lists methods to create data collection scenarios using the |:|:|:| | Azure Monitor Agent | [Configure data collection for Azure Monitor Agent](../agents/data-collection-rule-azure-monitor-agent.md) | Use the Azure portal to create a DCR that specifies events and performance counters to collect from a machine with Azure Monitor Agent. Then associate that rule with one or more virtual machines. Azure Monitor Agent will be installed on any machines that don't currently have it. | | | [Enable VM insights overview](../vm/vminsights-enable-overview.md) | When you enable VM insights on a VM, the Azure Monitor agent is installed, and a DCR is created that collects a predefined set of performance counters. You shouldn't modify this DCR. |-| Container insights | [Enable Container insights](../containers/prometheus-metrics-enable.md) | When you enable Container insights on a Kubernetes cluster, a containerized version of the Azure Monitor agent is installed, and a DCR is created that collects data according to the configuration you selected. You may need to modify this DCR to add a transformation. | +| Container insights | [Enable Container insights](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) | When you enable Container insights on a Kubernetes cluster, a containerized version of the Azure Monitor agent is installed, and a DCR is created that collects data according to the configuration you selected. You may need to modify this DCR to add a transformation. | | Text or JSON logs | [Collect logs from a text or JSON file with Azure Monitor Agent](../agents/data-collection-text-log.md?tabs=portal) | Use the Azure portal to create a DCR to collect entries from a text log on a machine with Azure Monitor Agent. | | Workspace transformation | [Add a transformation in a workspace data collection rule using the Azure portal](../logs/tutorial-workspace-transformations-portal.md) | Create a transformation for any supported table in a Log Analytics workspace. The transformation is defined in a DCR that's then associated with the workspace. It's applied to any data sent to that table from a legacy workload that doesn't use a DCR. | |
azure-monitor | Prometheus Grafana | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/essentials/prometheus-grafana.md | Title: Use Azure Monitor managed service for Prometheus as data source for Grafa description: Details on how to configure Azure Monitor managed service for Prometheus as data source for both Azure Managed Grafana and self-hosted Grafana in an Azure virtual machine. Previously updated : 09/28/2022 Last updated : 01/08/2024 # Use Azure Monitor managed service for Prometheus as data source for Grafana using managed system identity This section provides answers to common questions. ## Next steps - [Configure self-managed Grafana to use Azure-managed Prometheus with Microsoft Entra ID](./prometheus-self-managed-grafana-azure-active-directory.md).-- [Collect Prometheus metrics for your AKS cluster](../essentials/prometheus-metrics-enable.md).+- [Collect Prometheus metrics for your AKS cluster](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana). - [Configure Prometheus alerting and recording rules groups](prometheus-rule-groups.md). - [Customize scraping of Prometheus metrics](prometheus-metrics-scrape-configuration.md). |
azure-monitor | Prometheus Metrics Overview | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/essentials/prometheus-metrics-overview.md | Azure Monitor managed service for Prometheus can currently collect data from any ## Enable The only requirement to enable Azure Monitor managed service for Prometheus is to create an [Azure Monitor workspace](azure-monitor-workspace-overview.md), which is where Prometheus metrics are stored. Once this workspace is created, you can onboard services that collect Prometheus metrics. -- To collect Prometheus metrics from your AKS cluster without using Container insights, see [Collect Prometheus metrics from AKS cluster](prometheus-metrics-enable.md).-- To add collection of Prometheus metrics to your cluster using Container insights, see [Collect Prometheus metrics with Container insights](../containers/container-insights-prometheus.md#send-data-to-azure-monitor-managed-service-for-prometheus).+- To collect Prometheus metrics from your Kubernetes cluster, see [Enable monitoring for Kubernetes clusters](../containers/kubernetes-monitoring-enable.md). - To configure remote-write to collect data from your self-managed Prometheus server, see [Azure Monitor managed service for Prometheus remote write - managed identity](prometheus-remote-write-managed-identity.md).-- To collect Prometheus metrics from your Azure Arc-enabled Kubernetes cluster without using Container insights, see [Collect Prometheus metrics from Azure Arc-enabled Kubernetes cluster](./prometheus-metrics-from-arc-enabled-cluster.md) ## Grafana integration The primary method for visualizing Prometheus metrics is [Azure Managed Grafana](../../managed-grafan#link-a-grafana-workspace) so that it can be used as a data source in a Grafana dashboard. You then have access to multiple prebuilt dashboards that use Prometheus metrics and the ability to create any number of custom dashboards. See [Azure Monitor service limits](../service-limits.md#prometheus-metrics) for - Scraping and storing metrics at frequencies less than 1 second isn't supported. - Metrics with the same label names but different cases are rejected during ingestion (ex;- `diskSize(cluster="eastus", node="node1", filesystem="usr_mnt", FileSystem="usr_opt")` is invalid due to `filesystem` and `FileSystem` labels, and are rejected). - Microsoft Azure operated by 21Vianet cloud and Air gapped clouds aren't supported for Azure Monitor managed service for Prometheus.-- To monitor Windows nodes & pods in your cluster(s), follow steps outlined [here](./prometheus-metrics-enable.md#enable-windows-metrics-collection).+- To monitor Windows nodes & pods in your cluster(s), follow steps outlined [here](../containers/kubernetes-monitoring-enable.md#enable-windows-metrics-collection-preview). - Azure Managed Grafana isn't currently available in the Azure US Government cloud. - Usage metrics (metrics under `Metrics` menu for the Azure Monitor workspace) - Ingestion quota limits and current usage for any Azure monitor Workspace aren't available yet in US Government cloud. - During node updates, you might experience gaps lasting 1 to 2 minutes in some metric collections from our cluster level collector. This gap is due to a regular action from Azure Kubernetes Service to update the nodes in your cluster. This behavior is expected and occurs due to the node it runs on being updated. None of our recommended alert rules are affected by this behavior. If you use the Azure portal to enable Prometheus metrics collection and install ## Next steps -- [Enable Azure Monitor managed service for Prometheus](prometheus-metrics-enable.md).+- [Enable Azure Monitor managed service for Prometheus on your Kubernetes clusters](../containers/kubernetes-monitoring-enable.md). - [Configure Prometheus alerting and recording rules groups](prometheus-rule-groups.md). - [Customize scraping of Prometheus metrics](prometheus-metrics-scrape-configuration.md). |
azure-monitor | Prometheus Rule Groups | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/essentials/prometheus-rule-groups.md | |
azure-monitor | Prometheus Self Managed Grafana Azure Active Directory | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/essentials/prometheus-self-managed-grafana-azure-active-directory.md | This section provides answers to common questions. ## Next steps - [Configure Grafana using managed system identity](./prometheus-grafana.md).-- [Collect Prometheus metrics for your AKS cluster](../essentials/prometheus-metrics-enable.md).+- [Collect Prometheus metrics for your AKS cluster](../containers/kubernetes-monitoring-enable.md). - [Configure Prometheus alerting and recording rules groups](prometheus-rule-groups.md). - [Customize scraping of Prometheus metrics](prometheus-metrics-scrape-configuration.md). |
azure-monitor | Prometheus Workbooks | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/essentials/prometheus-workbooks.md | This article introduces workbooks for Azure Monitor workspaces and shows you how ## Prerequisites To query Prometheus metrics from an Azure Monitor workspace, you need the following: - An Azure Monitor workspace. To create an Azure Monitor workspace, see [Create an Azure Monitor Workspace](./azure-monitor-workspace-overview.md?tabs=azure-portal.md).-- Your Azure Monitor workspace must be [collecting Prometheus metrics](./prometheus-metrics-enable.md) from an AKS cluster.+- Your Azure Monitor workspace must be [collecting Prometheus metrics](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) from an AKS cluster. - The user must be assigned role that can perform the **microsoft.monitor/accounts/read** operation on the Azure Monitor workspace. ## Prometheus Explorer workbook This section provides answers to common questions. [!INCLUDE [prometheus-faq-i-see-gaps-in-metric-data](../includes/prometheus-faq-i-see-gaps-in-metric-data.md)] ## Next steps-* [Collect Prometheus metrics from AKS cluster](./prometheus-metrics-enable.md) +* [Collect Prometheus metrics from AKS cluster](../containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana) * [Azure Monitor workspace](./azure-monitor-workspace-overview.md) * [Use Azure Monitor managed service for Prometheus as data source for Grafana using managed system identity](./prometheus-grafana.md) |
azure-monitor | Resource Manager Samples | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/resource-manager-samples.md | In the request body, provide a link to your template and parameter file. - [Metric alert rules](alerts/resource-manager-alerts-metric.md): Configure alerts from metrics that use different kinds of logic. - [Application Insights](app/resource-manager-app-resource.md) - [Diagnostic settings](essentials/resource-manager-diagnostic-settings.md): Create diagnostic settings to forward logs and metrics from different resource types.-- [Enable Prometheus metrics](essentials/prometheus-metrics-enable.md?tabs=resource-manager#enable-prometheus-metric-collection): Install the Azure Monitor agent on your AKS cluster and send Prometheus metrics to your Azure Monitor workspace.+- [Enable Prometheus metrics](containers/kubernetes-monitoring-enable.md?tabs=arm#enable-prometheus-and-grafana): Install the Azure Monitor agent on your AKS cluster and send Prometheus metrics to your Azure Monitor workspace. - [Log queries](logs/resource-manager-log-queries.md): Create saved log queries in a Log Analytics workspace. - [Log Analytics workspace](logs/resource-manager-workspace.md): Create a Log Analytics workspace and configure a collection of data sources from the Log Analytics agent. - [Workbooks](visualize/resource-manager-workbooks.md): Create workbooks. |
azure-monitor | Workbooks Composite Bar | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-composite-bar.md | The composite bar view for a graph with the preceding settings will look like th ## Next steps -[Get started with Azure Workbooks](workbooks-getting-started.md) +[Get started with Azure Workbooks](workbooks-overview.md) |
azure-monitor | Workbooks Configurations | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-configurations.md | - Title: Azure Monitor workbooks with custom parameters -description: Simplify complex reporting with prebuilt and custom parameterized workbooks. ----- Previously updated : 06/21/2023---# Workbook configuration options --You can configure workbooks to suit your needs by using the settings in the **Settings** tab. If query or metrics steps display time-based data, more settings are available on the **Advanced settings** tab. --## Workbook settings --Workbook settings have these tabs to help you configure your workbook. --|Settings tab |Description | -||| -|Resources|This tab contains the resources that appear as default selections in this workbook.<br>The resource marked as the **Owner** is where the workbook will be saved and the location of the workbooks and templates you'll see when you're browsing. The owner resource can't be removed.<br> You can add a default resource by selecting **Add Resources**. You can remove resources by selecting a resource or several resources and selecting **Remove Selected Resources**. When you're finished adding and removing resources, select **Apply Changes**.| -|Versions| This tab contains a list of all the available versions of this workbook. Select a version and use the toolbar to compare, view, or restore versions. Previous workbook versions are available for 90 days.<br><ul><li>**Compare**: Compares the JSON of the previous workbook to the most recently saved version.</li><li>**View**: Opens the selected version of the workbook in a context pane.</li><li>**Restore**: Saves a new copy of the workbook with the contents of the selected version and overwrites any existing current content. You'll be prompted to confirm this action.</li></ul><br>| -|Style |On this tab, you can set a padding and spacing style for the whole workbook. The possible options are **Wide**, **Standard**, **Narrow**, and **None**. The default style setting is **Standard**.| -|Pin |While in pin mode, you can select **Pin Workbook** to pin a component from this workbook to a dashboard. Select **Link to Workbook** to pin a static link to this workbook on your dashboard. You can choose a specific component in your workbook to pin.| -|Trusted hosts |On this tab, you can enable a trusted source or mark this workbook as trusted in this browser. For more information, see [Trusted hosts](#trusted-hosts). | --> [!NOTE] -> Version history isn't available for [bring-your-own-storage](workbooks-bring-your-own-storage.md) workbooks. --#### Versions tab ---#### Compare versions ---### Trusted hosts --Enable a trusted source or mark this workbook as trusted in this browser. --| Control | Definition | -| -- | -- | -| Mark workbook as trusted | If enabled, this workbook can call any endpoint, whether the host is marked as trusted or not. A workbook is trusted if it's a new workbook, an existing workbook that's saved, or is explicitly marked as a trusted workbook. | -| URL grid | A grid to explicitly add trusted hosts. | --## Time brushing --Time range brushing allows a user to "brush" or "scrub" a range on a chart and have that range output as a parameter value. ---You can also choose to only export a parameter when a range is explicitly brushed: ---### Brushing in a metrics chart --When you enable time brushing on a metrics chart, you can "brush" a time by dragging the mouse on the time chart. ---After the brush has stopped, the metrics chart zooms in to that range and exports the range as a time range parameter. -An icon on the toolbar in the upper-right corner is active to reset the time range back to its original, unzoomed time range. --### Brushing in a query chart --When you enable time brushing on a query chart, indicators appear that you can drag, or you can brush a range on the time chart. ---After the brush has stopped, the query chart shows that range as a time range parameter but won't zoom in. This behavior is different than the behavior of metrics charts. Because of the complexity of user-written queries, it might not be possible for workbooks to correctly update the range used by the query in the query content directly. If the query is using a time range parameter, it's possible to get this behavior by using a [global parameter](workbooks-parameters.md#global-parameters) instead. --An icon on the toolbar in the upper-right corner is active to reset the time range back to its original, unzoomed time range. --## Interactivity --There are several ways that you can create interactive reports and experiences in workbooks: ---### Set up a grid row click --1. Make sure you're in edit mode by selecting **Edit**. -1. Select **Add query** to add a log query control to the workbook. -1. Select the log query type, the resource type, and the target resources. -1. Use the query editor to enter the KQL for your analysis: -- ```kusto - requests - | summarize AllRequests = count(), FailedRequests = countif(success == false) by Request = name - | order by AllRequests desc - ``` --1. Select **Run query** to see the results. -1. Select **Advanced Settings** to open the **Advanced Settings** pane. -1. Select the **When an item is selected, export a parameter** checkbox. -1. Select **Add Parameter** and fill in the following information: - - **Field to export**: `Request` - - **Parameter name**: `SelectedRequest` - - **Default value**: `All requests` - - :::image type="content" source="media/workbooks-configurations/workbooks-export-parameters-add.png" alt-text="Screenshot that shows the Advanced Settings workbook editor with settings for exporting fields as parameters."::: --1. Optional. If you want to export the entire contents of the selected row instead of a specific column, leave **Field to export** unset. The entire row's contents are exported as JSON to the parameter. On the referencing KQL control, use the `todynamic` function to parse the JSON and access the individual columns. -1. Select **Save**. -1. Select **Done Editing**. -1. Add another query control as in the preceding steps. -1. Use the query editor to enter the KQL for your analysis. -- ```kusto - requests - | where name == '{SelectedRequest}' or 'All Requests' == '{SelectedRequest}' - | summarize ['{SelectedRequest}'] = count() by bin(timestamp, 1h) - ``` --1. Select **Run query** to see the results. -1. Change **Visualization** to **Area chart**. -1. Choose a row to select in the first grid. Note how the area chart below filters to the selected request. --The resulting report looks like this example in edit mode: - - :::image type="content" source="media/workbooks-configurations/workbooks-interactivity-grid-create.png" alt-text="Screenshot that shows workbooks with the first two queries in edit mode."::: --The following image shows a more elaborate interactive report in read mode based on the same principles. The report uses grid clicks to export parameters, which in turn are used in two charts and a text block. -- :::image type="content" source="media/workbooks-configurations/workbooks-interactivity-grid-read.png" alt-text="Screenshot that shows a workbook report using grid clicks."::: --### Set up grid cell clicks --1. Make sure you're in edit mode by selecting **Edit**. -1. Select **Add query** to add a log query control to the workbook. -1. Select the log query type, resource type, and target resources. -1. Use the query editor to enter the KQL for your analysis: -- ```kusto - requests - | summarize Count = count(), Sample = any(pack_all()) by Request = name - | order by Count desc - ``` --1. Select **Run query** to see the results. -1. Select **Column Settings** to open the settings pane. -1. In the **Columns** section, set: - - **Sample** - - **Column renderer**: `Link` - - **View to open**: `Cell Details` - - **Link label**: `Sample` - - **Count** - - **Column renderer**: `Bar` - - **Color palette**: `Blue` - - **Minimum value**: `0` - - **Request** - - **Column renderer**: `Automatic` -1. Select **Save and Close** to apply changes. -- :::image type="content" source="media/workbooks-configurations/workbooks-column-settings.png" alt-text="Screenshot that shows the Edit column settings pane."::: --1. Select a **Sample** link in the grid to open a pane with the details of a sampled request. -- :::image type="content" source="media/workbooks-configurations/workbooks-grid-link-details.png" alt-text="Screenshot that shows the Details pane of the sample request."::: --### Link renderer actions --Learn about how [link actions](workbooks-link-actions.md) work to enhance workbook interactivity. --### Set conditional visibility --1. Follow the steps in the [Set up a grid row click](#set-up-a-grid-row-click) section to set up two interactive controls. -1. Add a new parameter with these values: - - **Parameter name**: `ShowDetails` - - **Parameter type**: `Drop down` - - **Required**: `checked` - - **Get data from**: `JSON` - - **JSON Input**: `["Yes", "No"]` -1. Select **Save** to commit changes. -- :::image type="content" source="media/workbooks-configurations/workbooks-edit-parameter.png" alt-text="Screenshot that shows editing an interactive parameter in workbooks."::: --1. Set the parameter value to `Yes`. - - :::image type="content" source="media/workbooks-configurations/workbooks-set-parameter.png" alt-text="Screenshot that shows setting an interactive parameter value in a workbook."::: --1. In the query control with the area chart, select **Advanced Settings** (the gear icon). -1. If **ShowDetails** is set to `Yes`, select **Make this item conditionally visible**. -1. Select **Done Editing** to commit the changes. -1. On the workbook toolbar, select **Done Editing**. -1. Switch the value of **ShowDetails** to `No`. Notice that the chart below disappears. --The following image shows the case where **ShowDetails** is `Yes`: -- :::image type="content" source="media/workbooks-configurations/workbooks-conditional-visibility-visible.png" alt-text="Screenshot that shows a workbook with a conditional component that's visible."::: --The following image shows the hidden case where **ShowDetails** is `No`: ---### Set up multi-selects in grids and charts --Query and metrics components can export parameters when a row or multiple rows are selected. ---1. In the query component that displays the grid, select **Advanced settings**. -1. Select the **When items are selected, export parameters** checkbox. -1. Select the **Allow selection of multiple values** checkbox. - - The displayed visualization allows multi-selecting and the exported parameter's values will be arrays of values, like when using multi-select dropdown parameters. - - If cleared, the display visualization only captures the last selected item and exports only a single value at a time. -1. Use **Add Parameter** for each parameter you want to export. A pop-up window appears with the settings for the parameter to be exported. --When you enable single selection, you can specify which field of the original data to export. Fields include parameter name, parameter type, and default value to use if nothing is selected. --When you enable multi-selection, you specify which field of the original data to export. Fields include parameter name, parameter type, quote with, and delimiter. The quote with and delimiter values are used when turning arrow values into text when they're being replaced in a query. In multi-selection, if no values are selected, the default value is an empty array. --> [!NOTE] -> For multi-selection, only unique values are exported. For example, you won't see output array values like "1,1,2,1". The array output will be "1,2". --If you leave the **Field to export** setting empty in the export settings, all the available fields in the data will be exported as a stringified JSON object of key:value pairs. For grids and titles, the string includes the fields in the grid. For charts, the available fields are x,y,series, and label, depending on the type of chart. --While the default behavior is to export a parameter as text, if you know the field is a subscription or resource ID, use that information as the export parameter type. Then the parameter can be used downstream in places that require those types of parameters. |
azure-monitor | Workbooks Create Workbook | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-create-workbook.md | Title: Creating an Azure Workbook + Title: Create or edit an Azure Workbook description: Learn how to create an Azure Workbook. Previously updated : 06/21/2023- Last updated : 01/08/2024+ -# Creating an Azure Workbook +# Create or edit an Azure Workbook This article describes how to create a new workbook and how to add elements to your Azure Workbook. This video walks you through creating workbooks. To create a new Azure workbook: ## Add text -Workbooks allow authors to include text blocks in their workbooks. The text can be human analysis of the telemetry, information to help users interpret the data, section headings, etc. - +Workbooks allow authors to include text blocks in their workbooks. The text can be human analysis of the data, information to help users interpret the data, section headings, etc. + :::image type="content" source="media/workbooks-create-workbook/workbooks-text-example.png" lightbox="media/workbooks-create-workbook/workbooks-text-example.png" alt-text="Screenshot of adding text to a workbook."::: -Text is added through a markdown control into which an author can add their content. An author can use the full formatting capabilities of markdown. These include different heading and font styles, hyperlinks, tables, etc. Markdown allows authors to create rich Word- or Portal-like reports or analytic narratives. Text can contain parameter values in the markdown text, and those parameter references will be updated as the parameters change. +Text is added through a markdown control into which an author can add their content. An author can use the full formatting capabilities of markdown. These include different heading and font styles, hyperlinks, tables, etc. Markdown allows authors to create rich Word- or Portal-like reports or analytic narratives. Text can contain parameter values in the markdown text, and those parameter references are updated as the parameters change. **Edit mode**: <!-- convertborder later --> To add text to an Azure workbook: - Select the ellipses (...) to the right of the **Edit** button next to one of the elements in the workbook, then select **Add** and then **Add text**. 1. Enter markdown text into the editor field. 1. Use the **Text Style** option to switch between plain markdown, and markdown wrapped with the Azure portal's standard info/warning/success/error styling.- + > [!TIP] > Use this [markdown cheat sheet](https://github.com/adam-p/markdown-here/wiki/Markdown-Cheatsheet) to see the different formatting options. -1. Use the **Preview** tab to see how your content will look. The preview shows the content inside a scrollable area to limit its size, but when displayed at runtime, the markdown content will expand to fill whatever space it needs, without a scrollbar. +1. Use the **Preview** tab to see how your content looks. The preview shows the content inside a scrollable area to limit its size, but when displayed at runtime, the markdown content expands to fill whatever space it needs, without a scrollbar. 1. Select **Done Editing**. ### Text styles You can also choose a text parameter as the source of the style. The parameter v :::image type="content" source="media/workbooks-create-workbook/workbooks-text-control-edit-mode-preview.png" lightbox="media/workbooks-create-workbook/workbooks-text-control-edit-mode-preview.png" alt-text="Screenshot of adding text to a workbook in preview mode showing info style." border="false"::: **Warning style example**:- + :::image type="content" source="media/workbooks-create-workbook/workbooks-text-example-warning.png" lightbox="media/workbooks-create-workbook/workbooks-text-example-warning.png" alt-text="Screenshot of a text visualization in warning style."::: ## Add queries -Azure Workbooks allow you to query any of the supported workbook [data sources](workbooks-data-sources.md). +Azure Workbooks allow you to query any of the supported workbook [data sources](workbooks-data-sources.md). For example, you can query Azure Resource Health to help you view any service problems affecting your resources. You can also query Azure Monitor metrics, which is numeric data collected at regular intervals. Azure Monitor metrics provide information about an aspect of a system at a particular time. To add a query to an Azure Workbook: 1. When you're sure you have the query you want in your workbook, select **Done editing**. -### Best practices for querying logs +### Best practices for querying logs - **Use the smallest possible time ranges.** The longer the time ranges, the slower the queries, and the more data returned. For longer time ranges, the query might have to go to slower "cold" storage, making the query even slower. Default to the shortest useful time range, but allow the user to pick a larger time range that may be slower. - **Use the "All" special value in dropdowns.** You can add an **All** special item in the dropdown parameter settings. You can use a special value. Using an **All** special item correctly can dramatically simplify queries.+ - **Protect against missing columns.** If you're using a custom table or custom columns, design your template so that it works if the column is missing in a workspace. See the [column_ifexists](/azure/kusto/query/columnifexists) function. + - **Protect against a missing table.** If your template is installed as part of a solution, or in other cases where the tables are guaranteed to exist, checking for missing columns is unnecessary. If you're creating generic templates that could be visible on any resource or workspace, it's a good idea to protect for tables that don't exist. The log analytics query language doesn't have a **table_ifexists** function like the function for testing for columns. However, there are some ways to check if a table exists. For example, you can use a [fuzzy union](/azure/kusto/query/unionoperator?pivots=azuredataexplorer). When doing a union, you can use the **isfuzzy=true** setting to let the union continue if some of the tables don't exist. You can add a parameter query in your workbook that checks for existence of the table, and hides some content if it doesn't. Items that aren't visible aren't run, so you can design your template so that other queries in the workbook that would fail if the table doesn't exist, don't run until after the test verifies that the table exists. For example: ``` let MissingTable = view () { print isMissing=1 };- union isfuzzy=true MissingTable, (AzureDiagnostics | getschema | summarize c=count() | project isMissing=iff(c > 0, 0, 1)) + union isfuzzy=true MissingTable, (AzureDiagnostics | getschema | summarize c=count() | project isMissing=iff(c > 0, 0, 1)) | top 1 by isMissing asc ``` - This query returns a **1** if the **AzureDiagnostics** table doesn't exist in the workspace. If the real table doesn't exist, the fake row of the **MissingTable** will be returned. If any columns exist in the schema for the **AzureDiagnostics** table, a **0** is returned. You could use this as a parameter value, and conditionally hide your query steps unless the parameter value is 0. You could also use conditional visibility to show text that says that the current workspace does not have the missing table, and send the user to documentation on how to onboard. + This query returns a **1** if the **AzureDiagnostics** table doesn't exist in the workspace. If the real table doesn't exist, the fake row of the **MissingTable** will be returned. If any columns exist in the schema for the **AzureDiagnostics** table, a **0** is returned. You could use this as a parameter value, and conditionally hide your query steps unless the parameter value is 0. You could also use conditional visibility to show text that says that the current workspace doesn't have the missing table, and send the user to documentation on how to onboard. Instead of hiding steps, you may just want to have no rows as a result. You can change the **MissingTable** to be an empty data table with the appropriate matching schema:- + ``` let MissingTable = datatable(ResourceId: string) []; union isfuzzy=true MissingTable, (AzureDiagnostics This video shows you how to use resource level logs queries in Azure Workbooks. [![Making resource centric log queries in workbooks](https://img.youtube.com/vi/8CvjM0VvOA8/0.jpg)](https://youtu.be/8CvjM0VvOA8 "Video showing how to make resource centric log queries in workbooks") #### Dynamic resource type parameter-Uses dynamic scopes for more efficient querying. The snippet below uses this heuristc: +Uses dynamic scopes for more efficient querying. The snippet below uses this heuristic: 1. _Individual resources_: if the count of selected resource is less than or equal to 5 2. _Resource groups_: if the number of resources is over 5 but the number of resource groups the resources belong to is less than or equal to 3 3. _Subscriptions_: otherwise Resources | project x = dynamic(["microsoft.compute/virtualmachines", "microsoft.compute/virtualmachinescalesets", "microsoft.resources/resourcegroups", "microsoft.resources/subscriptions"]) | mvexpand x to typeof(string) | extend jkey = 1-| join kind = inner (Resources +| join kind = inner (Resources | where id in~ ({VirtualMachines}) | summarize Subs = dcount(subscriptionId), resourceGroups = dcount(resourceGroup), resourceCount = count() | extend jkey = 1) on jkey-| project x, label = 'x', +| project x, label = 'x', selected = case(- x in ('microsoft.compute/virtualmachinescalesets', 'microsoft.compute/virtualmachines') and resourceCount <= 5, true, - x == 'microsoft.resources/resourcegroups' and resourceGroups <= 3 and resourceCount > 5, true, - x == 'microsoft.resources/subscriptions' and resourceGroups > 3 and resourceCount > 5, true, + x in ('microsoft.compute/virtualmachinescalesets', 'microsoft.compute/virtualmachines') and resourceCount <= 5, true, + x == 'microsoft.resources/resourcegroups' and resourceGroups <= 3 and resourceCount > 5, true, + x == 'microsoft.resources/subscriptions' and resourceGroups > 3 and resourceCount > 5, true, false) ``` #### Static resource scope for querying multiple resource types Resources #### Resource parameter grouped by resource type ``` Resources-| where type =~ 'microsoft.compute/virtualmachines' or type =~ 'microsoft.compute/virtualmachinescalesets' -| where resourceGroup in~({ResourceGroups}) -| project value = id, label = id, selected = false, - group = iff(type =~ 'microsoft.compute/virtualmachines', 'Virtual machines', 'Virtual machine scale sets') +| where type =~ 'microsoft.compute/virtualmachines' or type =~ 'microsoft.compute/virtualmachinescalesets' +| where resourceGroup in~({ResourceGroups}) +| project value = id, label = id, selected = false, + group = iff(type =~ 'microsoft.compute/virtualmachines', 'Virtual machines', 'Virtual machine scale sets') ``` ## Add parameters You can collect input from consumers and reference it in other parts of the workbook using parameters. Use parameters to scope the result set or to set the right visual. Parameters help you build interactive reports and experiences. For more information on how parameters can be used, see [workbook parameters](workbooks-parameters.md). -Workbooks allow you to control how your parameter controls are presented to consumers ΓÇô text box vs. drop down, single- vs. multi-select, values from text, JSON, KQL, or Azure Resource Graph, etc. +Workbooks allow you to control how your parameter controls are presented to consumers ΓÇô text box vs. drop down, single- vs. multi-select, values from text, JSON, KQL, or Azure Resource Graph, etc. Watch this video to learn how to use parameters and log data in Azure Workbooks. > [!VIDEO https://www.microsoft.com/en-us/videoplayer/embed/RE59Wee] To add a parameter to an Azure Workbook: - Parameter name: Parameter names can't include spaces or special characters - Display name: Display names can include spaces, special characters, emoji, etc.- - Parameter type: - - Required: - + - Parameter type: + - Required: + 1. Select **Done editing**. <!-- convertborder later --> :::image type="content" source="media/workbooks-parameters/workbooks-time-settings.png" lightbox="media/workbooks-parameters/workbooks-time-settings.png" alt-text="Screenshot showing the creation of a time range parameter." border="false"::: ## Add metric charts -Most Azure resources emit metric data about state and health such as CPU utilization, storage availability, count of database transactions, failing app requests, etc. Using workbooks, you can create visualizations of the metric data as time-series charts. +Most Azure resources emit metric data about state and health such as CPU utilization, storage availability, count of database transactions, failing app requests, etc. Using workbooks, you can create visualizations of the metric data as time-series charts. ++The example below shows the number of transactions in a storage account over the prior hour. This allows the storage owner to see the transaction trend and look for anomalies in behavior. -The example below shows the number of transactions in a storage account over the prior hour. This allows the storage owner to see the transaction trend and look for anomalies in behavior. - :::image type="content" source="media/workbooks-create-workbook/workbooks-metric-chart-storage-area.png" lightbox="media/workbooks-create-workbook/workbooks-metric-chart-storage-area.png" alt-text="Screenshot showing a metric area chart for storage transactions in a workbook."::: To add a metric chart to an Azure Workbook: This is a metric chart in edit mode: <!-- convertborder later --> :::image type="content" source="media/workbooks-create-workbook/workbooks-metric-chart-storage-scatter.png" lightbox="media/workbooks-create-workbook/workbooks-metric-chart-storage-scatter.png" alt-text="Screenshot showing a metric scatter chart for storage latency." border="false"::: -## Add links +## Add links -You can use links to create links to other views, workbooks, other items inside a workbook, or to create tabbed views within a workbook. The links can be styled as hyperlinks, buttons, and tabs. +You can use links to create links to other views, workbooks, other items inside a workbook, or to create tabbed views within a workbook. The links can be styled as hyperlinks, buttons, and tabs. <!-- convertborder later --> :::image type="content" source="media/workbooks-create-workbook/workbooks-empty-links.png" lightbox="media/workbooks-create-workbook/workbooks-empty-links.png" alt-text="Screenshot of adding a link to a workbook." border="false"::: Links can use all of the link actions available in [link actions](workbooks-link | Action | Description | |:- |:-| |Set a parameter value | A parameter can be set to a value when selecting a link, button, or tab. Tabs are often configured to set a parameter to a value, which hides and shows other parts of the workbook based on that value.|-|Scroll to a step| When selecting a link, the workbook will move focus and scroll to make another step visible. This action can be used to create a "table of contents", or a "go back to the top" style experience. | +|Scroll to a step| When selecting a link, the workbook will move focus and scroll to make another step visible. This action can be used to create a "table of contents", or a "go back to the top" style experience.| ### Tabs -Most of the time, tab links are combined with the **Set a parameter value** action. Here's an example showing the links step configured to create 2 tabs, where selecting either tab will set a **selectedTab** parameter to a different value (the example shows a third tab being edited to show the parameter name and parameter value placeholders): +Most of the time, tab links are combined with the **Set a parameter value** action. Here's an example showing the links step configured to create 2 tabs, where selecting either tab sets a **selectedTab** parameter to a different value (the example shows a third tab being edited to show the parameter name and parameter value placeholders): <!-- convertborder later --> :::image type="content" source="media/workbooks-create-workbook/workbooks-creating-tabs.png" lightbox="media/workbooks-create-workbook/workbooks-creating-tabs.png" alt-text="Screenshot of creating tabs in workbooks." border="false"::: You can then add other items in the workbook that are conditionally visible if t <!-- convertborder later --> :::image type="content" source="media/workbooks-create-workbook/workbooks-selected-tab.png" lightbox="media/workbooks-create-workbook/workbooks-selected-tab.png" alt-text="Screenshot of conditionally visible tab in workbooks." border="false"::: -The first tab is selected by default, initially setting **selectedTab** to 1, and making that step visible. Selecting the second tab will change the value of the parameter to "2", and different content will be displayed: - +The first tab is selected by default, initially setting **selectedTab** to 1, and making that step visible. Selecting the second tab changes the value of the parameter to "2", and different content is displayed: + :::image type="content" source="media/workbooks-create-workbook/workbooks-selected-tab2.png" lightbox="media/workbooks-create-workbook/workbooks-selected-tab2.png" alt-text="Screenshot of workbooks with content displayed when selected tab is 2."::: A sample workbook with the above tabs is available in [sample Azure Workbooks with links](workbooks-sample-links.md#sample-workbook-with-links). g - URL links aren't supported in tabs. A URL link in a tab appears as a disabled tab. - No item styling is supported in tabs. Items are displayed as tabs, and only the tab name (link text) field is displayed. Fields that aren't used in tab style are hidden while in edit mode.+ - The first tab is selected by default, invoking whatever action that tab specified. If the first tab's action opens another view, as soon as the tabs are created, a view appears. + - You can use tabs to open another views, but this functionality should be used sparingly, since most users won't expect to navigate by selecting a tab. If other tabs are setting a parameter to a specific value, a tab that opens a view wouldn't change that value, so the rest of the workbook content continues to show the view or data for the previous tab. ### Toolbars Use the Toolbar style to have your links appear styled as a toolbar. In toolbar <!-- convertborder later --> :::image type="content" source="media/workbooks-create-workbook/workbooks-links-create-toolbar.png" lightbox="media/workbooks-create-workbook/workbooks-links-create-toolbar.png" alt-text="Screenshot of creating links styled as a toolbar in workbooks." border="false"::: -If any required parameters are used in button text, tooltip text, or value fields, and the required parameter is unset, the toolbar button will be disabled. For example, this can be used to disable toolbar buttons when no value is selected in another parameter/control. +If any required parameters are used in button text, tooltip text, or value fields, and the required parameter is unset, the toolbar button is disabled. For example, this can be used to disable toolbar buttons when no value is selected in another parameter/control. A sample workbook with toolbars, globals parameters, and ARM Actions is available in [sample Azure Workbooks with links](workbooks-sample-links.md#sample-workbook-with-toolbar-links). To add a group to your workbook: 1. Select items for your group. 1. Select **Done editing.** - This is a group in read mode with two items inside: a text item and a query item. + This is a group in read mode with two items inside: a text item and a query item. <!-- convertborder later --> :::image type="content" source="media/workbooks-create-workbook/workbooks-groups-view.png" lightbox="media/workbooks-create-workbook/workbooks-groups-view.png" alt-text="Screenshot showing a group in read mode in a workbook." border="false"::: A group is treated as a new scope in the workbook. Any parameters created in the You can specify which type of group to add to your workbook. There are two types of groups: - **Editable**: The group in the workbook allows you to add, remove, or edit the contents of the items in the group. This is most commonly used for layout and visibility purposes.+ - **From a template**: The group in the workbook loads from the contents of another workbook by its ID. The content of that workbook is loaded and merged into the workbook at runtime. In edit mode, you can't modify any of the contents of the group, as they'll just load again from the template next time the item loads. When loading a group from a template, use the full Azure Resource ID of an existing workbook. ### Load types For groups created from a template, the content of the template isn't retrieved #### Explicit loading -In this mode, a button is displayed where the group would be, and no content is retrieved or created until the user explicitly clicks the button to load the content. This is useful in scenarios where the content might be expensive to compute or rarely used. The author can specify the text to appear on the button. +In this mode, a button is displayed where the group would be, and no content is retrieved or created until the user explicitly selects the button to load the content. This is useful in scenarios where the content might be expensive to compute or rarely used. The author can specify the text to appear on the button. This screenshot shows explicit load settings with a configured "Load more" button. <!-- convertborder later --> This is the group before being loaded in the workbook: The group after being loaded in the workbook:- + :::image type="content" source="media/workbooks-create-workbook/workbooks-groups-explicitly-loaded-after.png" lightbox="media/workbooks-create-workbook/workbooks-groups-explicitly-loaded-after.png" alt-text="Screenshot showing an explicit group after being loaded in the workbook."::: #### Always mode In **Always** mode, the content of the group is always loaded and created as soo ### Using templates inside a group -When a group is configured to load from a template, by default, that content will be loaded in lazy mode, and it will only load when the group is visible. +When a group is configured to load from a template, by default, that content is loaded in lazy mode, and it will only load when the group is visible. -When a template is loaded into a group, the workbook attempts to merge any parameters declared in the template with parameters that already exist in the group. Any parameters that already exist in the workbook with identical names will be merged out of the template being loaded. If all parameters in a parameter step are merged out, the entire parameters step will disappear. +When a template is loaded into a group, the workbook attempts to merge any parameters declared in the template with parameters that already exist in the group. Any parameters that already exist in the workbook with identical names will be merged out of the template being loaded. If all parameters in a parameter step are merged out, the entire parameters step disappears. #### Example 1: All parameters have identical names If the loaded template had contained **TimeRange** and **Filter** (instead of ** ### Splitting a large template into many templates -To improve performance, it's helpful to break up a large template into multiple smaller templates that loads some content in lazy mode or on demand by the user. This makes the initial load faster since the top-level template can be much smaller. +To improve performance, it's helpful to break up a large template into multiple smaller templates that loads some content in lazy mode or on demand by the user. This makes the initial load faster since the top-level template can be smaller. When splitting a template into parts, you'll basically need to split the template into many templates (subtemplates) that all work individually. If the top-level template has a **TimeRange** parameter that other items use, the subtemplate will need to also have a parameters item that defines a parameter with same exact name. The subtemplates will work independently and can load inside larger templates in groups. To turn a larger template into multiple subtemplates: 1. Create a new empty group near the top of the workbook, after the shared parameters. This new group will eventually become a subtemplate. 1. Create a copy of the shared parameters step, and then use **move into group** to move the copy into the group created in step 1. This parameter allows the subtemplate to work independently of the outer template, and will get merged out when loaded inside the outer template.- + > [!NOTE] > Subtemplates don't technically need to have the parameters that get merged out if you never plan on the sub-templates being visible by themselves. However, if the sub-templates do not have the parameters, it will make them very hard to edit or debug if you need to do so later. 1. Move each item in the workbook you want to be in the subtemplate into the group created in step 1.-1. If the individual steps moved in step 3 had conditional visibilities, that will become the visibility of the outer group (like used in tabs). Remove them from the items inside the group and add that visibility setting to the group itself. Save here to avoid losing changes and/or export and save a copy of the json content. -1. If you want that group to be loaded from a template, you can use the **Edit** toolbar button in the group. This will open just the content of that group as a workbook in a new window. You can then save it as appropriate and close this workbook view (don't close the browser, just that view to go back to the previous workbook you were editing). +1. If the individual steps moved in step 3 had conditional visibilities, that becomes the visibility of the outer group (like used in tabs). Remove them from the items inside the group and add that visibility setting to the group itself. Save here to avoid losing changes and/or export and save a copy of the json content. +1. If you want that group to be loaded from a template, you can use the **Edit** toolbar button in the group. This opens just the content of that group as a workbook in a new window. You can then save it as appropriate and close this workbook view (don't close the browser, just that view to go back to the previous workbook you were editing). 1. You can then change the group step to load from template and set the template ID field to the workbook/template you created in step 5. To work with workbooks IDs, the source needs to be the full Azure Resource ID of a shared workbook. Press *Load* and the content of that group will now be loaded from that subtemplate instead of saved inside this outer workbook.++ |
azure-monitor | Workbooks Data Sources | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-data-sources.md | With [Azure Monitor managed service for Prometheus](../essentials/prometheus-met ## Next steps + - [Get started with Azure Workbooks](workbooks-overview.md) - [Create an Azure workbook](workbooks-create-workbook.md) |
azure-monitor | Workbooks Dropdowns | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-dropdowns.md | Title: Azure Monitor workbook dropdown parameters -description: Simplify complex reporting with prebuilt and custom parameterized workbooks containing dropdown parameters. +description: Use dropdown parameters to simplify complex reporting with prebuilt and custom parameterized workbooks. Other common examples use '*' as the special marker value when a parameter is re ## Next steps -[Getting started with Azure Workbooks](workbooks-getting-started.md) +[Learn about the types of visualizations you can use to create rich visual reports with Azure Workbooks](workbooks-visualizations.md). |
azure-monitor | Workbooks Getting Started | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-getting-started.md | - Title: Common Azure Workbooks tasks -description: Learn how to perform the commonly used tasks in workbooks. --- Previously updated : 06/21/2023----# Get started with Azure Workbooks --This article describes how to access Azure Workbooks and the common tasks used to work with workbooks. --You can access Azure Workbooks in a few ways: --- In the [Azure portal](https://portal.azure.com), select **Monitor** > **Workbooks** from the menu bars on the left.-- :::image type="content" source="./media/workbooks-overview/workbooks-menu.png" alt-text="Screenshot that shows Workbooks in the menu."::: --- On a **Log Analytics workspaces** page, select **Workbooks** at the top of the page.-- :::image type="content" source="media/workbooks-overview/workbooks-log-analytics-icon.png" alt-text="Screenshot of Workbooks on the Log Analytics workspaces page."::: --When the gallery opens, select a saved workbook or a template. You can also search for a name in the search box. --## Save a workbook --To save a workbook, save the report with a specific title, subscription, resource group, and location. --By default, the workbook is auto-filled with the same settings as the LA workspace, with the same subscription and resource group. Workbooks are saved to 'My Reports' by default, and are only accessible by the individual user, but they can be saved directly to shared reports or shared later on. Workbooks are shared resources and they require write access to the parent resource group to be saved. --## Share a workbook --When you want to share a workbook or template, keep in mind that the person you want to share with must have permissions to access the workbook. They must have an Azure account, and **Monitoring Reader** permissions. -To share a workbook or workbook template: --1. In the Azure portal, select the workbook or template you want to share. -1. Select the **Share** icon from the top toolbar. -1. The **Share workbook** or **Share template** window opens with a URL to use for sharing the workbook. -1. Copy the link to share the workbook, or select **Share link via email** to open your default mail app. ---## Pin a visualization --You can pin text, query, or metrics components in a workbook by using the **Pin** button on those items while the workbook is in pin mode. Or you can use the **Pin** button if the workbook author has enabled settings for that element to make it visible. --To access pin mode, select **Edit** to enter editing mode. Select **Pin** on the top bar. An individual **Pin** then appears above each corresponding workbook part's **Edit** button on the right side of the screen. ---> [!NOTE] -> The state of the workbook is saved at the time of the pin. Pinned workbooks on a dashboard won't update if the underlying workbook is modified. To update a pinned workbook part, you must delete and re-pin that part. --### Time ranges for pinned queries --Pinned workbook query parts will respect the dashboard's time range if the pinned item is configured to use a *TimeRange* parameter. The dashboard's time range value will be used as the time range parameter's value. Any change of the dashboard time range will cause the pinned item to update. If a pinned part is using the dashboard's time range, you'll see the subtitle of the pinned part update to show the dashboard's time range whenever the time range changes. --Pinned workbook parts using a time range parameter will auto-refresh at a rate determined by the dashboard's time range. The last time the query ran will appear in the subtitle of the pinned part. --If a pinned component has an explicitly set time range and doesn't use a time range parameter, that time range will always be used for the dashboard, regardless of the dashboard's settings. The subtitle of the pinned part won't show the dashboard's time range. The query won't auto-refresh on the dashboard. The subtitle will show the last time the query executed. --> [!NOTE] -> Queries that use the *merge* data source aren't currently supported when pinning to dashboards. --## Auto refresh --Select **Auto refresh** to open a list of intervals that you can use to select the interval. The workbook will keep refreshing after the selected time interval. --* **Auto refresh** only refreshes when the workbook is in read mode. If a user sets an interval of 5 minutes and after 4 minutes switches to edit mode, refreshing doesn't occur if the user is still in edit mode. But if the user returns to read mode, the interval of 5 minutes resets and the workbook will be refreshed after 5 minutes. -* Selecting **Auto refresh** in read mode also resets the interval. If a user sets the interval to 5 minutes and after 3 minutes the user selects **Auto refresh** to manually refresh the workbook, the **Auto refresh** interval resets and the workbook will be auto-refreshed after 5 minutes. -* This setting isn't saved with the workbook. Every time a user opens a workbook, **Auto refresh** is **Off** and needs to be set again. -* Switching workbooks and going out of the gallery clears the **Auto refresh** interval. ----## Next steps --[Azure Workbooks data sources](workbooks-data-sources.md) |
azure-monitor | Workbooks Interactive Reports | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-interactive-reports.md | + + Title: Create interactive reports with Azure Monitor Workbooks +description: This article explains how to create interactive reports in Azure Workbooks. + Last updated : 01/08/2024+++++# Create interactive reports with Azure Monitor Workbooks ++There are several ways that you can create interactive reports and experiences in workbooks: ++ - **Parameters**: When you update a [parameter](workbooks-parameters.md), any control that uses the parameter automatically refreshes and redraws to reflect the new value. This behavior is how most of the Azure portal reports support interactivity. Workbooks provide this functionality in a straightforward manner with minimal user effort. + - **Grid, tile, and chart selections**: You can construct scenarios where selecting a row in a grid updates subsequent charts based on the content of the row. For example, you might have a grid that shows a list of requests and some statistics like failure counts. You can set it up so that if you select the row of a request, the detailed charts below update to show only that request. Learn how to [set up a grid row click](#set-up-a-grid-row-click). + - **Grid cell clicks**: You can add interactivity with a special type of grid column renderer called a [link renderer](#link-renderer-actions). A link renderer converts a grid cell into a hyperlink based on the contents of the cell. Workbooks support many kinds of link renderers including renderers that open resource overview panes, property bag viewers, and Application Insights search, usage, and transaction tracing. Learn how to [set up a grid cell click](#set-up-grid-cell-clicks). + - **Conditional visibility**: You can make controls appear or disappear based on the values of parameters. This way you can have reports that look different based on user input or telemetry state. For example, you can show consumers a summary when there are no issues. You can also show detailed information when there's something wrong. Learn how to [set up conditional visibility](#set-conditional-visibility). + - **Export parameters with multi-selections**: You can export parameters from query and metrics workbook components when a row or multiple rows are selected. Learn how to [set up multi-selects in grids and charts](#set-up-multi-selects-in-grids-and-charts). ++## Set up a grid row click ++1. Make sure you're in edit mode by selecting **Edit**. +1. Select **Add query** to add a log query control to the workbook. +1. Select the log query type, the resource type, and the target resources. +1. Use the query editor to enter the KQL for your analysis: ++ ```kusto + requests + | summarize AllRequests = count(), FailedRequests = countif(success == false) by Request = name + | order by AllRequests desc + ``` ++1. Select **Run query** to see the results. +1. Select **Advanced Settings** to open the **Advanced Settings** pane. +1. Select the **When an item is selected, export a parameter** checkbox. +1. Select **Add Parameter** and fill in the following information: + - **Field to export**: `Request` + - **Parameter name**: `SelectedRequest` + - **Default value**: `All requests` + + :::image type="content" source="media/workbooks-configurations/workbooks-export-parameters-add.png" alt-text="Screenshot that shows the Advanced Settings workbook editor with settings for exporting fields as parameters."::: ++1. Optional. If you want to export the entire contents of the selected row instead of a specific column, leave **Field to export** unset. The entire row's contents are exported as JSON to the parameter. On the referencing KQL control, use the `todynamic` function to parse the JSON and access the individual columns. +1. Select **Save**. +1. Select **Done Editing**. +1. Add another query control as in the preceding steps. +1. Use the query editor to enter the KQL for your analysis. ++ ```kusto + requests + | where name == '{SelectedRequest}' or 'All Requests' == '{SelectedRequest}' + | summarize ['{SelectedRequest}'] = count() by bin(timestamp, 1h) + ``` ++1. Select **Run query** to see the results. +1. Change **Visualization** to **Area chart**. +1. Choose a row to select in the first grid. Note how the area chart below filters to the selected request. ++The resulting report looks like this example in edit mode: + + :::image type="content" source="media/workbooks-configurations/workbooks-interactivity-grid-create.png" alt-text="Screenshot that shows workbooks with the first two queries in edit mode."::: ++The following image shows a more elaborate interactive report in read mode based on the same principles. The report uses grid clicks to export parameters, which in turn are used in two charts and a text block. ++ :::image type="content" source="media/workbooks-configurations/workbooks-interactivity-grid-read.png" alt-text="Screenshot that shows a workbook report using grid clicks."::: ++## Set up grid cell clicks ++1. Make sure you're in edit mode by selecting **Edit**. +1. Select **Add query** to add a log query control to the workbook. +1. Select the log query type, resource type, and target resources. +1. Use the query editor to enter the KQL for your analysis: ++ ```kusto + requests + | summarize Count = count(), Sample = any(pack_all()) by Request = name + | order by Count desc + ``` ++1. Select **Run query** to see the results. +1. Select **Column Settings** to open the settings pane. +1. In the **Columns** section, set: + - **Sample** + - **Column renderer**: `Link` + - **View to open**: `Cell Details` + - **Link label**: `Sample` + - **Count** + - **Column renderer**: `Bar` + - **Color palette**: `Blue` + - **Minimum value**: `0` + - **Request** + - **Column renderer**: `Automatic` +1. Select **Save and Close** to apply changes. ++ :::image type="content" source="media/workbooks-configurations/workbooks-column-settings.png" alt-text="Screenshot that shows the Edit column settings pane."::: ++1. Select a **Sample** link in the grid to open a pane with the details of a sampled request. ++ :::image type="content" source="media/workbooks-configurations/workbooks-grid-link-details.png" alt-text="Screenshot that shows the Details pane of the sample request."::: ++## Link renderer actions ++Learn about how [link actions](workbooks-link-actions.md) work to enhance workbook interactivity. ++## Set conditional visibility ++1. Follow the steps in the [Set up a grid row click](#set-up-a-grid-row-click) section to set up two interactive controls. +1. Add a new parameter with these values: + - **Parameter name**: `ShowDetails` + - **Parameter type**: `Drop down` + - **Required**: `checked` + - **Get data from**: `JSON` + - **JSON Input**: `["Yes", "No"]` +1. Select **Save** to commit changes. ++ :::image type="content" source="media/workbooks-configurations/workbooks-edit-parameter.png" alt-text="Screenshot that shows editing an interactive parameter in workbooks."::: ++1. Set the parameter value to `Yes`. + + :::image type="content" source="media/workbooks-configurations/workbooks-set-parameter.png" alt-text="Screenshot that shows setting an interactive parameter value in a workbook."::: ++1. In the query control with the area chart, select **Advanced Settings** (the gear icon). +1. If **ShowDetails** is set to `Yes`, select **Make this item conditionally visible**. +1. Select **Done Editing** to commit the changes. +1. On the workbook toolbar, select **Done Editing**. +1. Switch the value of **ShowDetails** to `No`. Notice that the chart below disappears. ++The following image shows the case where **ShowDetails** is `Yes`: ++ :::image type="content" source="media/workbooks-configurations/workbooks-conditional-visibility-visible.png" alt-text="Screenshot that shows a workbook with a conditional component that's visible."::: ++The following image shows the hidden case where **ShowDetails** is `No`: +++## Set up multi-selects in grids and charts ++Query and metrics components can export parameters when a row or multiple rows are selected. +++1. In the query component that displays the grid, select **Advanced settings**. +1. Select the **When items are selected, export parameters** checkbox. +1. Select the **Allow selection of multiple values** checkbox. + - The displayed visualization allows multi-selecting and the exported parameter's values will be arrays of values, like when using multi-select dropdown parameters. + - If cleared, the display visualization only captures the last selected item and exports only a single value at a time. +1. Use **Add Parameter** for each parameter you want to export. A pop-up window appears with the settings for the parameter to be exported. ++When you enable single selection, you can specify which field of the original data to export. Fields include parameter name, parameter type, and default value to use if nothing is selected. ++When you enable multi-selection, you specify which field of the original data to export. Fields include parameter name, parameter type, quote with, and delimiter. The quote with and delimiter values are used when turning arrow values into text when they're being replaced in a query. In multi-selection, if no values are selected, the default value is an empty array. ++> [!NOTE] +> For multi-selection, only unique values are exported. For example, you won't see output array values like "1,1,2,1". The array output will be "1,2". ++If you leave the **Field to export** setting empty in the export settings, all the available fields in the data will be exported as a stringified JSON object of key:value pairs. For grids and titles, the string includes the fields in the grid. For charts, the available fields are x,y,series, and label, depending on the type of chart. ++While the default behavior is to export a parameter as text, if you know the field is a subscription or resource ID, use that information as the export parameter type. Then the parameter can be used downstream in places that require those types of parameters. ++## Capture user input to use in a query ++You can capture user input by using dropdown lists and use the selections in your queries. For example, you can have a dropdown list to accept a set of virtual machines and then filter your KQL to include just the selected machines. In most cases, this step is as simple as including the parameter's value in the query: ++```sql + Perf + | where Computer in ({Computers}) + | take 5 +``` ++In more advanced scenarios, you might need to transform the parameter results before they can be used in queries. Take this OData filter payload: ++```json +{ + "name": "deviceComplianceTrend", + "filter": "(OSFamily eq 'Android' or OSFamily eq 'OS X') and (ComplianceState eq 'Compliant')" +} +``` ++The following example shows how to enable this scenario. Let's say you want the values of the `OSFamily` and `ComplianceState` filters to come from dropdown lists in the workbook. The filter could include multiple values as in the preceding `OsFamily` case. It needs to also support the case where you want to include all dimension values, that is to say, with no filters. ++### Set up parameters ++1. [Create a new empty workbook](workbooks-create-workbook.md) and [add a parameter component](workbooks-create-workbook.md#add-parameters). +1. Select **Add parameter** to create a new parameter. Use the following settings: + - **Parameter name**: `OsFilter` + - **Display name**: `Operating system` + - **Parameter type**: `drop-down` + - **Allow multiple selections**: `Checked` + - **Delimiter**: `or` (with spaces before and after) + - **Quote with**: `<empty>` + - **Get data from**: `JSON` + - **JSON Input**: ++ ```json + [ + { "value": "OSFamily eq 'Android'", "label": "Android" }, + { "value": "OSFamily eq 'OS X'", "label": "OS X" } + ] + ``` ++ - In the **Include in the drop down** section: + - Select the **All** checkbox. + - **Select All value**: `OSFamily ne '#@?'` + - Select **Save** to save this parameter. +1. Add another parameter with these settings: + - **Parameter name**: `ComplianceStateFilter` + - **Display name**: `Compliance State` + - **Parameter type**: `drop-down` + - **Allow multiple selections**: `Checked` + - **Delimiter**: `or` (with spaces before and after) + - **Quote with**: `<empty>` + - **Get data from**: `JSON` + - **JSON Input**: ++ ```json + [ + { "value": "ComplianceState eq 'Compliant'", "label": "Compliant" }, + { "value": "ComplianceState eq 'Non-compliant'", "label": "Non compliant" } + ] + ``` + - In the **Include in the drop down** section: + - Select the **All** checkbox. + - **Select All value**: `ComplianceState ne '#@?'` + - Select **Save** to save this parameter. ++1. Select **Add text** to add a text block. In the **Markdown text to display** block, add: ++ ```json + { + "name": "deviceComplianceTrend", + "filter": "({OsFilter}) and ({ComplianceStateFilter})" + } + ``` ++ This screenshot shows the parameter settings: ++ :::image type="content" source="media/workbooks-commonly-used-components/workbooks-odata-parameters-settings.png" alt-text="Screenshot that shows parameter settings for dropdown lists with parameter values."::: ++### Single filter value ++The simplest case is the selection of a single filter value in each of the dimensions. The dropdown control uses the JSON input field's value as the parameter's value. ++```json +{ + "name": "deviceComplianceTrend", + "filter": "(OSFamily eq 'OS X') and (ComplianceState eq 'Compliant')" +} +``` +++### Multiple filter values ++If you choose multiple filter values, for example, both Android and OS X operating systems, the `Delimiter` and `Quote with` parameter settings kick in and produce this compound filter: ++```json +{ + "name": "deviceComplianceTrend", + "filter": "(OSFamily eq 'OS X' or OSFamily eq 'Android') and (ComplianceState eq 'Compliant')" +} +``` +++### No filter case ++Another common case is having no filter for that dimension. This scenario is equivalent to including all values of the dimensions as part of the result set. The way to enable it is by having an `All` option on the dropdown and have it return a filter expression that always evaluates to `true`. An example is _ComplianceState eq '#@?'_. ++```json +{ + "name": "deviceComplianceTrend", + "filter": "(OSFamily eq 'OS X' or OSFamily eq 'Android') and (ComplianceState ne '#@?')" +} +``` +++## Reuse query data in different visualizations ++There are times where you want to visualize the underlying dataset in different ways without having to pay the cost of the query each time. This sample shows you how to do so by using the `Merge` option in the query control. ++### Set up the parameters ++1. [Create a new empty workbook](workbooks-create-workbook.md). +1. Select **Add query** to create a query control, and enter these values: + - **Data source**: `Logs` + - **Resource type**: `Log Analytics` + - **Log Analytics workspace**: _Pick one of your workspaces that has performance data_ + - **Log Analytics workspace logs query**: ++ ```sql + Perf + | where CounterName == '% Processor Time' + | summarize CpuAverage = avg(CounterValue), CpuP95 = percentile(CounterValue, 95) by Computer + | order by CpuAverage desc + ``` ++1. Select **Run Query** to see the results. ++ This result dataset is the one we want to reuse in multiple visualizations. ++ :::image type="content" source="media/workbooks-commonly-used-components/workbooks-reuse-data-resultset.png" alt-text="Screenshot that shows the result of a workbooks query." lightbox="media/workbooks-commonly-used-components/workbooks-reuse-data-resultset.png"::: ++1. Go to the **Advanced settings** tab, and for the name, enter `Cpu data`. +1. Select **Add query** to create another query control. +1. For **Data source**, select `Merge`. +1. Select **Add Merge**. +1. In the settings pane, set: + - **Merge Type**: `Duplicate table` + - **Table**: `Cpu data` +1. Select **Run Merge**. You'll get the same result as the preceding. ++ :::image type="content" source="media/workbooks-commonly-used-components/workbooks-reuse-data-duplicate.png" alt-text=" Screenshot that shows duplicate query results in a workbook." lightbox="media/workbooks-commonly-used-components/workbooks-reuse-data-duplicate.png"::: ++1. Set the table options: + - Use the **Name After Merge** column to set friendly names for your result columns. For example, you can rename `CpuAverage` to `CPU utilization (avg)`, and then use **Run Merge** to update the result set. + - Use **Delete** to remove a column. + - Select the `[Cpu data].CpuP95` row. + - Use **Delete** in the query control toolbar. + - Use **Run Merge** to see the result set without the CpuP95 column +1. Change the order of the columns by selecting **Move up** or **Move down**. +1. Add new columns based on values of other columns by selecting **Add new item**. +1. Style the table by using the options in **Column settings** to get the visualization you want. +1. Add more query controls working against the `Cpu data` result set if needed. ++This example shows Average and P95 CPU utilization side by side: +++## Use Azure Resource Manager to retrieve alerts in a subscription ++This sample shows you how to use the Azure Resource Manager query control to list all existing alerts in a subscription. This guide will also use JSON Path transformations to format the results. See the [list of supported Resource Manager calls](/rest/api/azure/). ++### Set the parameters ++1. [Create a new empty workbook](workbooks-create-workbook.md). +1. Select **Add parameter**, and set: + - **Parameter name**: `Subscription` + - **Parameter type**: `Subscription picker` + - **Required**: `Checked` + - **Get data from**: `Default Subscriptions` +1. Select **Save**. +1. Select **Add query** to create a query control, and use these settings. For this example, we're using the [Alerts Get All REST call](/rest/api/monitor/alertsmanagement/alerts/getall) to get a list of existing alerts for a subscription. For supported api-versions, see the [Azure REST API reference](/rest/api/azure/). + - **Data source**: `Azure Resource Manager (Preview)` + - **Http Method**: `GET` + - **Path**: `/subscriptions/{Subscription:id}/providers/Microsoft.AlertsManagement/alerts` + - Add the api-version parameter on the **Parameters** tab and set: + - **Parameter**: `api-version` + - **Value**: `2018-05-05` ++1. Select a subscription from the created subscription parameter, and select **Run Query** to see the results. ++ This raw JSON is returned from Resource ++ :::image type="content" source="media/workbooks-commonly-used-components/workbooks-arm-alerts-query-no-formatting.png" alt-text="Screenshot that shows an alert data JSON response in workbooks by using a Resource Manager provider." lightbox="media/workbooks-commonly-used-components/workbooks-arm-alerts-query-no-formatting.png"::: ++### Format the response ++You might be satisfied with the information here. But let's extract some interesting properties and format the response in a way that's easy to read. ++1. Go to the **Result Settings** tab. +1. Switch **Result Format** from `Content` to `JSON Path`. [JSON Path](workbooks-jsonpath.md) is a workbook transformer. +1. In the JSON Path settings, set **JSON Path Table** to `$.value.[*].properties.essentials`. This extracts all `"value.*.properties.essentials"` fields from the returned JSON. +1. Select **Run Query** to see the grid. ++ :::image type="content" source="media/workbooks-commonly-used-components/workbooks-arm-alerts-query-grid.png" alt-text="Screenshot that shows alert data in a workbook in grid format by using a Resource Manager provider." lightbox="media/workbooks-commonly-used-components/workbooks-arm-alerts-query-grid.png"::: ++### Filter the results ++JSON Path also allows you to choose information from the generated table to show as columns. ++For example, if you want to filter the results to the columns **TargetResource**, **Severity**, **AlertState**, **AlertRule**, **Description**, **StartTime**, and **ResolvedTime**, you could add the following rows in the columns table in JSON Path: ++| Column ID | Column JSON Path | +| :- | :-: | +| TargetResource | $.targetResource | +| Severity | $.severity | +| AlertState | $.alertState | +| AlertRule | $.alertRule | +| Description | $.description | +| StartTime | $.startDateTime | +| ResolvedTime | $.monitorConditionResolvedDateTime | +++## Next steps ++* [Learn about the types of visualizations you can use to create rich visual reports with Azure Workbooks](workbooks-visualizations.md). +* [Use drop down parameters to simplify complex reporting](workbooks-dropdowns.md). |
azure-monitor | Workbooks Limits | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-limits.md | |
azure-monitor | Workbooks Link Actions | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-link-actions.md | Title: Azure Workbooks link actions description: This article explains how to use link actions in Azure Workbooks. Previously updated : 06/21/2023 Last updated : 12/13/2023 Link actions can be accessed through workbook link components or through column ## General link actions -| Link action | Action on click | +| Link action | Action on select | |:- |:-| |Generic Details| Shows the row values in a property grid context view. | |Cell Details| Shows the cell value in a property grid context view. Useful when the cell contains a dynamic type with information, for example, JSON with request properties like location and role instance. | Link actions can be accessed through workbook link components or through column ## Application Insights -| Link action | Action on click | +| Link action | Action on select | |:- |:-| |Custom Event Details| Opens the Application Insights search details with the custom event ID ("itemId") in the cell. | |Details| Similar to Custom Event Details except for dependencies, exceptions, page views, requests, and traces. | Link actions can be accessed through workbook link components or through column ## Azure resource -| Link action | Action on click | +| Link action | Action on select | |:- |:-| |ARM Deployment| Deploys an Azure Resource Manager (ARM) template. When this item is selected, more fields are displayed to let you configure which ARM template to open and parameters for the template. [See Azure Resource Manager deployment link settings](#azure-resource-manager-deployment-link-settings). | |Create Alert Rule| Creates an alert rule for a resource. | |Custom View| Opens a custom view. When this item is selected, more fields appear where you can configure the view extension, view name, and any parameters used to open the view. [See custom view link settings](#custom-view-link-settings). | |Metrics| Opens a metrics view. |-|Resource Overview| Opens the resource's view in the portal based on the resource ID value in the cell. You can also optionally set a submenu value that will open a specific menu item in the resource view. | +|Resource Overview| Opens the resource's view in the portal based on the resource ID value in the cell. You can also optionally set a submenu value that opens a specific menu item in the resource view. | |Workbook (Template)| Opens a workbook template. When this item is selected, more fields appear where you can configure what template to open. | ## Link settings This section defines where the template should come from and the parameters used | Source | Description | |:- |:-|-|Resource group id comes from| The resource ID is used to manage deployed resources. The subscription is used to manage deployed resources and costs. The resource groups are used like folders to organize and manage all your resources. If this value isn't specified, the deployment will fail. Select from **Cell**, **Column**, **Parameter**, and **Static Value** in [Link sources](#link-sources).| -|ARM template URI from| The URI to the ARM template itself. The template URI needs to be accessible to the users who will deploy the template. Select from **Cell**, **Column**, **Parameter**, and **Static Value** in [Link sources](#link-sources). For more information, see [Azure quickstart templates](https://azure.microsoft.com/resources/templates/).| -|ARM Template Parameters|Defines the template parameters used for the template URI defined earlier. These parameters are used to deploy the template on the run page. The grid contains an **Expand** toolbar button to help fill the parameters by using the names defined in the template URI and set to static empty values. This option can only be used when there are no parameters in the grid and the template URI has been set. The lower section is a preview of what the parameter output looks like. Select **Refresh** to update the preview with current changes. Parameters are typically values. References are something that could point to key vault secrets that the user has access to. <br/><br/> **Template Viewer pane limitation** doesn't render reference parameters correctly and will show up as null/value. As a result, users won't be able to correctly deploy reference parameters from the **Template Viewer** tab.| +|Resource group ID comes from| The resource ID is used to manage deployed resources. The subscription is used to manage deployed resources and costs. The resource groups are used like folders to organize and manage all your resources. If this value isn't specified, the deployment fails. Select from **Cell**, **Column**, **Parameter**, and **Static Value** in [Link sources](#link-sources).| +|ARM template URI from| The URI to the ARM template itself. The template URI needs to be accessible to the users who deploy the template. Select from **Cell**, **Column**, **Parameter**, and **Static Value** in [Link sources](#link-sources). For more information, see [Azure Quickstart Templates](https://azure.microsoft.com/resources/templates/).| +|ARM Template Parameters|Defines the template parameters used for the template URI defined earlier. These parameters are used to deploy the template on the run page. The grid contains an **Expand** toolbar button to help fill the parameters by using the names defined in the template URI and set to static empty values. This option can only be used when there are no parameters in the grid and the template URI is set. The lower section is a preview of what the parameter output looks like. Select **Refresh** to update the preview with current changes. Parameters are typically values. References are something that could point to key vault secrets that the user has access to. <br/><br/> **Template Viewer pane limitation** doesn't render reference parameters correctly and will show up as null/value. As a result, users won't be able to correctly deploy reference parameters from the **Template Viewer** tab.| <!-- convertborder later --> :::image type="content" source="./media/workbooks-link-actions/template-settings.png" lightbox="./media/workbooks-link-actions/template-settings.png" alt-text="Screenshot that shows the Template Settings tab." border="false"::: ### UX settings -This section configures what you'll see before you run the Resource Manager deployment. +This section configures what you see before you run the Resource Manager deployment. | Source | Description | |:- |:-| |Title from| Title used on the run view. Select from **Cell**, **Column**, **Parameter**, and **Static Value** in [Link sources](#link-sources).| |Description from| The Markdown text used to provide a helpful description to users when they want to deploy the template. Select from **Cell**, **Column**, **Parameter**, and **Static Value** in [Link sources](#link-sources). <br/><br/> If you select **Static Value**, a multi-line text box appears. In this text box, you can resolve parameters by using `"{paramName}"`. Also, you can treat columns as parameters by appending `"_column"` after the column name like `{columnName_column}`. In the following example image, you can reference the column `"VMName"` by writing `"{VMName_column}"`. The value after the colon is the [parameter formatter](../visualize/workbooks-parameters.md#parameter-formatting-options). In this case, it's **value**.|-|Run button text from| Label used on the run (execute) button to deploy the ARM template. Users will select this button to start deploying the ARM template.| +|Run button text from| Label used on the run (execute) button to deploy the ARM template. Users select this button to start deploying the ARM template.| <!-- convertborder later --> :::image type="content" source="./media/workbooks-link-actions/ux-settings.png" lightbox="./media/workbooks-link-actions/ux-settings.png" alt-text="Screenshot that shows the Resource Manager UX Settings tab." border="false"::: After these configurations are set, when you select the link, the view opens wit ## Custom view link settings -Use this setting to open **Custom Views** in the Azure portal. Verify the configuration and settings. Incorrect values will cause errors in the portal or fail to open the views correctly. There are two ways to configure the settings: via the form or URL. +Use this setting to open **Custom Views** in the Azure portal. Verify the configuration and settings. Incorrect values cause errors in the portal or fail to open the views correctly. There are two ways to configure the settings: via the form or URL. > [!NOTE] > Views with a menu can't be opened in a context tab. If a view with a menu is configured to open in a context tab, no context tab is shown when the link is selected. If the selected link type is **Workbook (Template)**, you must specify more sett | Setting | Description | |:- |:-|-|Workbook owner Resource Id comes from| This value is the Resource ID of the Azure resource that "owns" the workbook. Commonly, it's an Application Insights resource or a Log Analytics workspace. Inside of Azure Monitor, this value might also be the literal string `"Azure Monitor"`. When the workbook is saved, this value is what the workbook is linked to. | +|Workbook owner Resource ID comes from| This value is the Resource ID of the Azure resource that "owns" the workbook. Commonly, it's an Application Insights resource or a Log Analytics workspace. Inside of Azure Monitor, this value might also be the literal string `"Azure Monitor"`. When the workbook is saved, this value is what the workbook is linked to. | |Workbook resources come from| An array of Azure Resource IDs that specify the default resource used in the workbook. For example, if the template being opened shows virtual machine metrics, the values here would be virtual machine resource IDs. Many times, the owner and resources are set to the same settings. |-|Template Id comes from| Specify the ID of the template to be opened. A community template from the gallery is the most common case. Prefix the path to the template with `Community-`, like `Community-Workbooks/Performance/Apdex` for the `Workbooks/Performance/Apdex` template. If it's a link to a saved workbook or template, use the full Azure resource ID of that item. | +|Template ID comes from| Specify the ID of the template to be opened. A community template from the gallery is the most common case. Prefix the path to the template with `Community-`, like `Community-Workbooks/Performance/Apdex` for the `Workbooks/Performance/Apdex` template. If it's a link to a saved workbook or template, use the full path to the Azure resource ID of that item, for example, "/subscriptions/12345678-a1b2-1234-a1b2-c3d4e5f6/resourceGroups/rgname/providers/microsoft.insights/workbooks/1a2b3c4d-5678-abcd-xyza-1a2b3c4d5e6f. | |Workbook Type comes from| Specify the kind of workbook template to open. The most common cases use the default or workbook option to use the value in the current workbook. | |Gallery Type comes from| This value specifies the gallery type that's displayed in the **Gallery** view of the template that opens. The most common cases use the default or workbook option to use the value in the current workbook. |-|Location comes from| The location field should be specified if you're opening a specific workbook resource. If location isn't specified, finding the workbook content is much slower. If you know the location, specify it. If you don't know the location or are opening a template with no specific location, leave this field as `Default`.| +|Location comes from| The location field should be specified if you're opening a specific workbook resource. If location isn't specified, finding the workbook content is slower. If you know the location, specify it. If you don't know the location or are opening a template with no specific location, leave this field as `Default`.| |Pass specific parameters to template| Select to pass specific parameters to the template. If selected, only the specified parameters are passed to the template or else all the parameters in the current workbook are passed to the template. In that case, the parameter *names* must be the same in both workbooks for this parameter value to work.| |Workbook Template Parameters| This section defines the parameters that are passed to the target template. The name should match with the name of the parameter in the target template. Select from **Cell**, **Column**, **Parameter**, and **Static Value**. The name and value must not be empty to pass that parameter to the target template.| -For each of the preceding settings, you must choose where the value in the linked workbook will come from. See [Link sources](#link-sources). +For each of the preceding settings, you must choose where the value in the linked workbook comes from. See [Link sources](#link-sources). When the workbook link is opened, the new workbook view is passed to all the values configured from the preceding settings. <!-- convertborder later --> When the workbook link is opened, the new workbook view is passed to all the val |Cell| Use the value in that cell in the grid as the link value. | |Column| When selected, a field appears where you can select another column in the grid. The value of that column for the row is used in the link value. This link value is commonly used to enable each row of a grid to open a different template by setting the **Template Id** field to **column**. Or it's used to open the same workbook template for different resources, if the **Workbook resources** field is set to a column that contains an Azure Resource ID. | |Parameter| When selected, a field appears where you can select a parameter. The value of that parameter is used for the value when the link is selected. |-|Static Value| When selected, a field appears where you can enter a static value that's used in the linked workbook. This value is commonly used when all the rows in the grid will use the same value for a field. | +|Static Value| When selected, a field appears where you can enter a static value that's used in the linked workbook. This value is commonly used when all the rows in the grid use the same value for a field. | |Component| Use the value set in the current component of the workbook. It's common in query and metrics components to set the workbook resources in the linked workbook to those resources used in the query/metrics component, not the current workbook. | |Workbook| Use the value set in the current workbook. | |Default| Use the default value that would be used if no value were specified. This situation is common for **Gallery Type comes from**, where the default gallery would be set by the type of the owner resource. | |
azure-monitor | Workbooks Manage | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-manage.md | + + Title: Manage Azure Monitor workbooks +description: Understand how to Manage Azure Workbooks ++ Last updated : 01/08/2024+++# Manage Azure Monitor Workbooks +This article describes how to manage Azure Workbooks in the Azure portal. ++## Save a workbook ++Workbooks are shared resources. They require write access to the parent resource group to be saved. ++1. In the Azure portal, select the workbook. +2. Select **Save**. +1. Enter the **title**, **subscription**, **resource group**, and **location**. +1. Select **Save**. ++By default, the workbook is auto-filled with the same settings, subscription and resource group as the LA workspace. +By default, workbooks are saved to 'My Reports' and are only accessible by the individual user. You can also save the workbook directly to shared reports or share the workbook. ++## Share a workbook ++When you want to share a workbook or template, keep in mind that the person you want to share with must have permissions to access the workbook. They must have an Azure account, and **Monitoring Reader** permissions. +To share a workbook or workbook template: ++1. In the Azure portal, select **Monitor**, and then select **Workbooks** from the left pane. +1. Select the checkbox next to the workbook or template you want to share. +1. Select the **Share** icon from the top toolbar. +1. The **Share workbook** or **Share template** window opens with a URL to use for sharing the workbook. +1. Copy the link to share the workbook, or select **Share link via email** to open your default mail app. +++## Delete a workbook ++1. In the Azure portal, select **Monitor**, and then select **Workbooks** from the left pane. +1. Select the checkbox next to the Workbook you want to delete. +1. Select **Delete** from the top toolbar. ++## Recover a deleted workbook +When you delete an Azure Workbook, it is soft-deleted and can be recovered by contacting support. After the soft-delete period, the workbook and its content are nonrecoverable and queued for purge completely within 30 days. + +> [!NOTE] +> Workbooks that were saved using bring your own storage cannot be recovered by support. You may be able to recover the workbook content from the storage account if the storage account used has enabled soft delete. ++## Set up Auto refresh ++1. In the Azure portal, select the workbook. +1. Select **Auto refresh**, and then to select from a list of intervals for the auto-refresh. The workbook will start refreshing after the selected time interval. ++- Auto refresh only applies when the workbook is in read mode. If a user sets an interval of 5 minutes and after 4 minutes switches to edit mode, refreshing doesn't occur if the user is still in edit mode. But if the user returns to read mode, the interval of 5 minutes resets and the workbook will be refreshed after 5 minutes. +- Selecting **Auto refresh** in read mode also resets the interval. If a user sets the interval to 5 minutes and after 3 minutes the user selects **Auto refresh** to manually refresh the workbook, the **Auto refresh** interval resets and the workbook will be auto-refreshed after 5 minutes. +- The **Auto refresh** setting isn't saved with the workbook. Every time a user opens a workbook, **Auto refresh** is **Off** and needs to be set again. +- Switching workbooks and going out of the gallery clears the **Auto refresh** interval. ++++## Manage workbook resources ++In the **Resources** section of the **Settings** tab, you can manage the resources in your workbook. ++- The workbook is saved in the resource marked as the **Owner**. When you browse workbooks, this is the location of the workbooks and templates you see when browsing. Select **Browse across galleries** to see the workbooks for all your resources. +- The owner resource can't be removed. +- Select **Add Resources** to add a default resource. +- Select **Remove Selected Resources** to remove resources by selecting a resource or several resources. +- When you're finished adding and removing resources, select **Apply Changes**. ++## Manage workbook versions +++The versions tab contains a list of all the available versions of this workbook. Select a version and use the toolbar to compare, view, or restore versions. Previous workbook versions are available for 90 days. +- **Compare**: Compares the JSON of the previous workbook to the most recently saved version. +- **View**: Opens the selected version of the workbook in a context pane. +- **Restore**: Saves a new copy of the workbook with the contents of the selected version and overwrites any existing current content. You're prompted to confirm this action. ++### Compare versions +++> [!NOTE] +> Version history isn't available for [bring-your-own-storage](workbooks-bring-your-own-storage.md) workbooks. ++## Manage workbook styles +On this tab, you can set a padding and spacing style for the whole workbook. The possible options are **Wide**, **Standard**, **Narrow**, and **None**. The default style setting is **Standard**. ++## Pinning workbooks ++You can pin text, query, or metrics components in a workbook by using the **Pin** button on those items while the workbook is in pin mode. Or you can use the **Pin** button if the workbook author enabled settings for that element to make it visible. ++While in pin mode, you can select **Pin Workbook** to pin a component from this workbook to a dashboard. Select **Link to Workbook** to pin a static link to this workbook on your dashboard. You can choose a specific component in your workbook to pin. ++To access pin mode, select **Edit** to enter editing mode. Select **Pin** on the top bar. An individual **Pin** then appears above each corresponding workbook part's **Edit** button on the right side of the screen. +++> [!NOTE] +> The state of the workbook is saved at the time of the pin. Pinned workbooks on a dashboard won't update if the underlying workbook is modified. To update a pinned workbook part, you must delete and re-pin that part. ++### Time ranges for pinned queries ++Pinned workbook query parts respect the dashboard's time range if the pinned item is configured to use a *TimeRange* parameter. The dashboard's time range value is used as the time range parameter's value. Any change of the dashboard time range causes the pinned item to update. If a pinned part is using the dashboard's time range, the subtitle of the pinned part updates to show the dashboard's time range whenever the time range changes. ++Pinned workbook parts using a time range parameter auto-refresh at a rate determined by the dashboard's time range. The last time the query ran appears in the subtitle of the pinned part. ++If a pinned component has an explicitly set time range and doesn't use a time range parameter, that time range is always used for the dashboard, regardless of the dashboard's settings. The subtitle of the pinned part doesn't show the dashboard's time range. The query doesn't auto-refresh on the dashboard. The subtitle shows the last time the query executed. ++> [!NOTE] +> Queries that use the *merge* data source aren't currently supported when pinning to dashboards. ++### Enable Trusted hosts ++Enable a trusted source or mark this workbook as trusted in this browser. ++| Control | Definition | +| -- | -- | +| Mark workbook as trusted | If enabled, this workbook can call any endpoint, whether the host is marked as trusted or not. A workbook is trusted if it's a new workbook, an existing workbook that's saved, or is explicitly marked as a trusted workbook. | +| URL grid | A grid to explicitly add trusted hosts. | |
azure-monitor | Workbooks Overview | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-overview.md | Workbooks are helpful for scenarios such as: Watch this video to see how you can use Azure Workbooks to get insights and visualize your data. > [!VIDEO https://www.microsoft.com/en-us/videoplayer/embed/RE5a1su] +## Accessing Azure Workbooks ++You can get to Azure workbooks in a few ways: ++- In the [Azure portal](https://portal.azure.com), select **Monitor** > **Workbooks** from the menu bars on the left. ++ :::image type="content" source="./media/workbooks-overview/workbooks-menu.png" alt-text="Screenshot that shows Workbooks in the menu."::: ++- In a **Log Analytics workspaces** page, select **Workbooks** at the top of the page. ++ :::image type="content" source="media/workbooks-overview/workbooks-log-analytics-icon.png" alt-text="Screenshot of Workbooks on the Log Analytics workspaces page."::: ++When the gallery opens, select a saved workbook or a template. You can also search for a name in the search box. + ## The gallery The gallery lists all the saved workbooks and templates in your current environment. Select **Browse across galleries** to see the workbooks for all your resources. Standard Azure roles that provide access to workbooks: For custom roles, you must add `microsoft.insights/workbooks/write` to the user's permissions to edit and save a workbook. For more information, see the [Workbook Contributor](../../role-based-access-control/built-in-roles.md#monitoring-contributor) role. + ## Next steps -[Get started with Azure Workbooks](workbooks-getting-started.md) +[Create an Azure Workbook](workbooks-create-workbook.md) |
azure-monitor | Workbooks Resources | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-resources.md | This approach can be used to bind resources to other controls like metrics. ## Next steps -[Getting started with Azure Workbooks](workbooks-getting-started.md) +[Getting started with Azure Workbooks](workbooks-overview.md) |
azure-monitor | Workbooks Retrieve Legacy Workbooks | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-retrieve-legacy-workbooks.md | - Title: Retrieve legacy and private workbooks -description: Learn how to retrieve deprecated legacy and private Azure workbooks. --- Previously updated : 06/21/2023-----# Retrieve legacy Application Insights workbooks --Private and legacy workbooks have been deprecated and aren't accessible from the Azure portal. If you're looking for the deprecated workbook that you forgot to convert before the deadline, you can use this process to retrieve the content of your old workbook and load it into a new workbook. This tool will only be available for a limited time. --Application Insights Workbooks, also known as "Legacy Workbooks", are stored as a different Azure resource type than all other Azure Workbooks. These different Azure resource types are now being merged one single standard type so that you can take advantage of all the existing and new functionality available in standard Azure Workbooks. For example: --* Converted legacy workbooks can be queried via Azure Resource Graph (ARG), and show up in other standard Azure views of resources in a resource group or subscription. -* Converted legacy workbooks can support top level ARM template features like other resource types, including, but not limited to: - * Tags - * Policies - * Activity Log / Change Tracking - * Resource locks -* Converted legacy workbooks can support [ARM templates](workbooks-automate.md). -* Converted legacy workbooks can support the [BYOS](workbooks-bring-your-own-storage.md) feature. -* Converted legacy workbooks can be saved in region of your choice. --The legacy workbook deprecation doesn't change where you find your workbooks in the Azure portal. The legacy workbooks are still visible in the Workbooks section of Application Insights. The deprecation won't affect the content of your workbook. --> [!NOTE] -> -> - After April 15 2021, you will not be able to save legacy workbooks. -> - Use `Save as` on a legacy workbook to create a standard Azure workbook. -> - Any new workbook you create will be a standard workbook. --## Why isn't there an automatic conversion? -- The write permissions for legacy workbooks are only based on Azure role based access control on the Application Insights resource itself. A user may not be allowed to create new workbooks in that resource group. If the workbooks were auto migrated, they could fail to be moved, or they could be created but then a user might not be able to delete them after the fact.-- Legacy workbooks support "My" (private) workbooks, which is no longer supported by Azure Workbooks. A migration would cause those private workbooks to become publicly visible to users with read access to that same resource group.-- Usage of links/group content loaded from saved Legacy workbooks would become broken. Authors will need to manually update these links to point to the new saved items.--For these reasons, we suggest that users manually migrate the workbooks they want to keep. -## Convert a legacy Application Insights workbook -1. Identify legacy workbooks. In the gallery view, legacy workbooks have a warning icon. When you open a legacy workbook, there's a banner. -- :::image type="content" source="media/workbooks-retrieve-legacy-workbooks/workbooks-legacy-warning.png" alt-text="Screenshot of the warning symbol on a deprecated workbook."::: -- :::image type="content" source="media/workbooks-retrieve-legacy-workbooks/workbooks-legacy-banner.png" alt-text="Screenshot of the banner at the top of a deprecated workbook."::: --1. Convert the legacy workbooks. For any legacy workbook you want to keep after June 30 2021: -- 1. Open the workbook, and then from the toolbar, select **Edit**, then **Save As**. - 1. Enter the workbook name. - 1. Select a subscription, resource group, and region where you have write access. - 1. If the Legacy Workbook uses links to other Legacy Workbooks, or loading workbook content in groups, those items will need to be updated to point to the newly saved workbook. - 1. After you have saved the workbook, you can delete the legacy Workbook, or update its contents to be a link to the newly saved workbook. --1. Verify permissions. For legacy workbooks, permissions were based on the Application Insights specific roles, like Application Insights Contributor. Verify that users of the new workbook have the appropriate standard Monitoring Reader/Contributor or Workbook Reader/Contributor roles so that they can see and create Workbooks in the appropriate resource groups. --For more information, see [access control](workbooks-overview.md#access-control). --After deprecation of the legacy workbooks, you'll still be able to retrieve the content of Legacy Workbooks for a limited time by using Azure CLI or PowerShell tools, to query `microsoft.insights/components/[name]/favorites` for the specific resource using `api-version=2015-05-01`. -## Convert a private workbook --1. Open a new or empty workbook. -1. In the toolbar, select **Edit** and then navigate to the advanced editor. -- :::image type="content" source="media/workbooks-retrieve-legacy-workbooks/workbooks-retrieve-deprecated-advanced-editor.png" alt-text="Screenshot of the advanced editor used to retrieve deprecated workbooks."::: --1. Copy the [workbook json](#json-for-private-workbook-conversion) and paste it into your open advanced editor. -1. Select **Apply** at the top right. -1. Select the subscription and resource group and category of the workbook you'd like to retrieve. -1. The grid at the bottom of this workbook lists all the private workbooks in the selected subscription or resource group. -1. Select one of the workbooks in the grid. Your workbook should look something like this: -- :::image type="content" source="media/workbooks-retrieve-legacy-workbooks/workbooks-retrieve-deprecated-private.png" alt-text="Screenshot of a deprecated private workbook converted to a standard workbook." lightbox="media//workbooks-retrieve-legacy-workbooks/workbooks-retrieve-deprecated-private.png"::: --1. Select **Open Content as Workbook** at the bottom of the workbook. -1. A new workbook appears with the content of the old private workbook that you selected. Save the workbook as a standard workbook. -1. You have to re-create links to the deprecated workbook or its contents, including dashboard pins and URL links. -## Convert a favorites-based (legacy) workbook - -1. Navigate to your Application Insights Resource > Workbooks gallery. -1. Open a new or empty workbook. -1. Select Edit in the toolbar and navigate to the advanced editor. -- :::image type="content" source="media/workbooks-retrieve-legacy-workbooks/workbooks-retrieve-deprecated-advanced-editor.png" alt-text="Screenshot of the advanced editor used to retrieve deprecated workbooks."::: --1. Copy the [workbook json](#json-for-private-workbook-conversion) and paste it into your open advanced editor. -1. Select **Apply**. -1. The grid at the bottom of this workbook lists all the legacy workbooks within the current AppInsights resource. -1. Select one of the workbooks in the grid. Your workbook should now look something like this: -- :::image type="content" source="media/workbooks-retrieve-legacy-workbooks/workbooks-retrieve-deprecated-legacy.png" alt-text="Screenshot of a deprecated legacy workbook converted to a standard workbook." lightbox="media/workbooks-retrieve-legacy-workbooks/workbooks-retrieve-deprecated-legacy.png"::: --1. Select **Open Content as Workbook** at the bottom of the workbook. -1. A new workbook appears with the content of the old private workbook that you selected. Save the workbook as a standard workbook. -1. You have to re-create links to the deprecated workbook or its contents, including dashboard pins and URL links. --## JSON for legacy workbook conversion --```json -{ - "version": "Notebook/1.0", - "items": [ - { - "type": 9, - "content": { - "version": "KqlParameterItem/1.0", - "parameters": [ - { - "id": "876235fc-ef67-418d-87f5-69f496be171b", - "version": "KqlParameterItem/1.0", - "name": "resource", - "type": 5, - "typeSettings": { - "additionalResourceOptions": [ - "value::1" - ], - "componentIdOnly": true - }, - "timeContext": { - "durationMs": 86400000 - }, - "defaultValue": "value::1" - } - ], - "style": "pills", - "queryType": 0, - "resourceType": "microsoft.insights/components" - }, - "conditionalVisibility": { - "parameterName": "debug", - "comparison": "isNotEqualTo" - }, - "name": "resource selection" - }, - { - "type": 1, - "content": { - "json": "# Legacy (Favorites based) Workbook Conversion\r\n\r\nThis workbook shows favorite based (legacy) workbooks in this Application Insights resource: \r\n\r\n{resource:grid}\r\n\r\nThe grid below will show the favorite workbooks found, and allows you to copy the contents, or open them as a full Azure Workbook where they can be saved." - }, - "name": "text - 5" - }, - { - "type": 3, - "content": { - "version": "KqlItem/1.0", - "query": "{\"version\":\"ARMEndpoint/1.0\",\"data\":null,\"headers\":[],\"method\":\"GETARRAY\",\"path\":\"{resource}/favorites\",\"urlParams\":[{\"key\":\"api-version\",\"value\":\"2015-05-01\"},{\"key\":\"sourceType\",\"value\":\"notebook\"},{\"key\":\"canFetchContent\",\"value\":\"false\"}],\"batchDisabled\":false,\"transformers\":[{\"type\":\"jsonpath\",\"settings\":{\"columns\":[{\"path\":\"$.Name\",\"columnid\":\"name\"},{\"path\":\"$.FavoriteId\",\"columnid\":\"id\"},{\"path\":\"$.TimeModified\",\"columnid\":\"modified\",\"columnType\":\"datetime\"},{\"path\":\"$.FavoriteType\",\"columnid\":\"type\"}]}}]}", - "size": 0, - "title": "Legacy Workbooks (Select an item to see contents)", - "noDataMessage": "No legacy workbooks found", - "noDataMessageStyle": 3, - "exportedParameters": [ - { - "fieldName": "id", - "parameterName": "favoriteId" - }, - { - "fieldName": "name", - "parameterName": "name", - "parameterType": 1 - } - ], - "queryType": 12, - "gridSettings": { - "rowLimit": 1000, - "filter": true - } - }, - "name": "list favorites" - }, - { - "type": 9, - "content": { - "version": "KqlParameterItem/1.0", - "parameters": [ - { - "id": "8d78556d-a4f3-4868-bf06-9e0980246d31", - "version": "KqlParameterItem/1.0", - "name": "config", - "type": 1, - "query": "{\"version\":\"ARMEndpoint/1.0\",\"data\":null,\"headers\":[],\"method\":\"GET\",\"path\":\"{resource}/favorites/{favoriteId}\",\"urlParams\":[{\"key\":\"api-version\",\"value\":\"2015-05-01\"},{\"key\":\"sourceType\",\"value\":\"notebook\"},{\"key\":\"canFetchContent\",\"value\":\"true\"}],\"batchDisabled\":false,\"transformers\":[{\"type\":\"jsonpath\",\"settings\":{\"columns\":[{\"path\":\"$.Config\",\"columnid\":\"Content\"}]}}]}", - "timeContext": { - "durationMs": 86400000 - }, - "queryType": 12 - } - ], - "style": "pills", - "queryType": 12 - }, - "conditionalVisibility": { - "parameterName": "debug", - "comparison": "isNotEqualTo" - }, - "name": "turn response into param" - }, - { - "type": 11, - "content": { - "version": "LinkItem/1.0", - "style": "list", - "links": [ - { - "id": "fc93ee9e-d5b2-41de-b74a-1fb62f0df49e", - "linkTarget": "OpenBlade", - "linkLabel": "Open Content as Workbook", - "style": "primary", - "bladeOpenContext": { - "bladeName": "UsageNotebookBlade", - "extensionName": "AppInsightsExtension", - "bladeParameters": [ - { - "name": "ComponentId", - "source": "parameter", - "value": "resource" - }, - { - "name": "NewNotebookData", - "source": "parameter", - "value": "config" - } - ] - } - } - ] - }, - "conditionalVisibility": { - "parameterName": "config", - "comparison": "isNotEqualTo" - }, - "name": "links - 4" - } - ], - "$schema": "https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json" -} -``` ---## JSON for private workbook conversion --```json -{ - "version": "Notebook/1.0", - "items": [ - { - "type": 9, - "content": { - "version": "KqlParameterItem/1.0", - "crossComponentResources": [ - "{Subscription}" - ], - "parameters": [ - { - "id": "1f74ed9a-e3ed-498d-bd5b-f68f3836a117", - "version": "KqlParameterItem/1.0", - "name": "Subscription", - "type": 6, - "isRequired": true, - "typeSettings": { - "additionalResourceOptions": [ - "value::1" - ], - "includeAll": false, - "showDefault": false - } - }, - { - "id": "b616a3a3-4271-4208-b1a9-a92a78efed08", - "version": "KqlParameterItem/1.0", - "name": "ResourceGroup", - "label": "Resource group", - "type": 2, - "isRequired": true, - "query": "Resources\r\n| summarize by resourceGroup\r\n| order by resourceGroup asc\r\n| project id=resourceGroup, resourceGroup", - "crossComponentResources": [ - "{Subscription}" - ], - "typeSettings": { - "additionalResourceOptions": [ - "value::1" - ], - "showDefault": false - }, - "queryType": 1, - "resourceType": "microsoft.resourcegraph/resources" - }, - { - "id": "3872fc90-1467-4b01-81ef-d82d90665d72", - "version": "KqlParameterItem/1.0", - "name": "Category", - "type": 2, - "description": "Workbook Category", - "isRequired": true, - "typeSettings": { - "additionalResourceOptions": [], - "showDefault": false - }, - "jsonData": "[\"workbook\",\"sentinel\",\"usage\",\"tsg\",\"usageMetrics\",\"workItems\",\"performance-websites\",\"performance-appinsights\",\"performance-documentdb\",\"performance-storage\",\"performance-storageclassic\",\"performance-vm\",\"performance-vmclassic\",\"performance-sqlserverdatabases\",\"performance-virtualnetwork\",\"performance-virtualmachinescalesets\",\"performance-computedisks\",\"performance-networkinterfaces\",\"performance-logicworkflows\",\"performance-appserviceplans\",\"performance-applicationgateway\",\"performance-runbooks\",\"performance-servicebusqueues\",\"performance-iothubs\",\"performance-networkroutetables\",\"performance-cognitiveserviceaccounts\",\"performance-containerservicemanagedclusters\",\"performance-servicefabricclusters\",\"performance-cacheredis\",\"performance-eventhubnamespaces\",\"performance-hdinsightclusters\",\"failure-websites\",\"failure-appinsights\",\"failure-documentdb\",\"failure-storage\",\"failure-storageclassic\",\"failure-vm\",\"failure-vmclassic\",\"failure-sqlserverdatabases\",\"failure-virtualnetwork\",\"failure-virtualmachinescalesets\",\"failure-computedisks\",\"failure-networkinterfaces\",\"failure-logicworkflows\",\"failure-appserviceplans\",\"failure-applicationgateway\",\"failure-runbooks\",\"failure-servicebusqueues\",\"failure-iothubs\",\"failure-networkroutetables\",\"failure-cognitiveserviceaccounts\",\"failure-containerservicemanagedclusters\",\"failure-servicefabricclusters\",\"failure-cacheredis\",\"failure-eventhubnamespaces\",\"failure-hdinsightclusters\",\"storage-insights\",\"cosmosdb-insights\",\"vm-insights\",\"container-insights\",\"keyvaults-insights\",\"backup-insights\",\"rediscache-insights\",\"servicebus-insights\",\"eventhub-insights\",\"workload-insights\",\"adxcluster-insights\",\"wvd-insights\",\"activitylog-insights\",\"hdicluster-insights\",\"laws-insights\",\"hci-insights\"]", - "defaultValue": "workbook" - } - ], - "queryType": 1, - "resourceType": "microsoft.resourcegraph/resources" - }, - "name": "resource selection" - }, - { - "type": 1, - "content": { - "json": "# Private Workbook Conversion\r\n\r\nThis workbook shows private workbooks within the current subscription / resource group: \r\n\r\n| Subscription | Resource Group | \r\n|--|-|\r\n|{Subscription}|{ResourceGroup} |\r\n\r\nThe grid below will show the private workbooks found, and allows you to copy the contents, or open them as a full Azure Workbook where they can be saved.\r\n\r\nUse the button below to load the selected private workbook content into a new workbook. From there you can save it as a new workbook." - }, - "name": "text - 5" - }, - { - "type": 3, - "content": { - "version": "KqlItem/1.0", - "query": "{\"version\":\"ARMEndpoint/1.0\",\"data\":null,\"headers\":[],\"method\":\"GETARRAY\",\"path\":\"/{Subscription}/resourceGroups/{ResourceGroup}/providers/microsoft.insights/myworkbooks\",\"urlParams\":[{\"key\":\"api-version\",\"value\":\"2020-10-20\"},{\"key\":\"category\",\"value\":\"{Category}\"}],\"batchDisabled\":false,\"transformers\":[{\"type\":\"jsonpath\",\"settings\":{\"tablePath\":\"$..[?(@.kind == \\\"user\\\")]\",\"columns\":[{\"path\":\"$.properties.displayName\",\"columnid\":\"name\"},{\"path\":\"$.name\",\"columnid\":\"id\"},{\"path\":\"$.kind\",\"columnid\":\"type\",\"columnType\":\"string\"},{\"path\":\"$.properties.timeModified\",\"columnid\":\"modified\",\"columnType\":\"datetime\"},{\"path\":\"$.properties.sourceId\",\"columnid\":\"resource\",\"columnType\":\"string\"}]}}]}", - "size": 1, - "title": "Private Workbooks", - "noDataMessage": "No private workbooks found", - "noDataMessageStyle": 3, - "exportedParameters": [ - { - "fieldName": "id", - "parameterName": "id" - }, - { - "fieldName": "name", - "parameterName": "name", - "parameterType": 1 - }, - { - "fieldName": "resource", - "parameterName": "resource", - "parameterType": 1 - } - ], - "queryType": 12, - "gridSettings": { - "formatters": [ - { - "columnMatch": "resource", - "formatter": 13, - "formatOptions": { - "linkTarget": null, - "showIcon": true - } - } - ], - "rowLimit": 1000, - "filter": true, - "labelSettings": [ - { - "columnId": "resource", - "label": "Linked To" - } - ] - }, - "sortBy": [] - }, - "name": "list private workbooks" - }, - { - "type": 9, - "content": { - "version": "KqlParameterItem/1.0", - "parameters": [ - { - "id": "8d78556d-a4f3-4868-bf06-9e0980246d31", - "version": "KqlParameterItem/1.0", - "name": "config", - "type": 1, - "query": "{\"version\":\"ARMEndpoint/1.0\",\"data\":null,\"headers\":[],\"method\":\"GET\",\"path\":\"{Subscription}/resourceGroups/{ResourceGroup}/providers/microsoft.insights/myworkbooks/{id}\",\"urlParams\":[{\"key\":\"api-version\",\"value\":\"2020-10-20\"},{\"key\":\"sourceType\",\"value\":\"notebook\"},{\"key\":\"canFetchContent\",\"value\":\"true\"}],\"batchDisabled\":false,\"transformers\":[{\"type\":\"jsonpath\",\"settings\":{\"columns\":[{\"path\":\"$..serializedData\",\"columnid\":\"Content\"}]}}]}", - "timeContext": { - "durationMs": 86400000 - }, - "queryType": 12 - } - ], - "style": "pills", - "queryType": 12 - }, - "conditionalVisibility": { - "parameterName": "debug", - "comparison": "isNotEqualTo" - }, - "name": "turn response into param" - }, - { - "type": 11, - "content": { - "version": "LinkItem/1.0", - "style": "list", - "links": [ - { - "id": "fc93ee9e-d5b2-41de-b74a-1fb62f0df49e", - "linkTarget": "OpenBlade", - "linkLabel": "Open Content as Workbook", - "style": "primary", - "bladeOpenContext": { - "bladeName": "UsageNotebookBlade", - "extensionName": "AppInsightsExtension", - "bladeParameters": [ - { - "name": "ComponentId", - "source": "parameter", - "value": "resource" - }, - { - "name": "NewNotebookData", - "source": "parameter", - "value": "config" - } - ] - } - } - ] - }, - "conditionalVisibility": { - "parameterName": "config", - "comparison": "isNotEqualTo" - }, - "name": "links - 4" - } - ], - "$schema": "https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json" -} -``` |
azure-monitor | Workbooks Text | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-text.md | If data is coming from a query, you can select the option to pre-format the JSON ## Next steps -[Get started with Azure Workbooks](workbooks-getting-started.md) +[Get started with Azure Workbooks](workbooks-overview.md) |
azure-monitor | Workbooks Time Brushing | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-time-brushing.md | + + Title: Azure Workbooks time brushing +description: Learn about time brushing in Azure Monitor workbooks. ++ Last updated : 01/08/2024++++# Time range brushing ++Time range brushing allows a user to "brush" or "scrub" a range on a chart and have that range output as a parameter value. +++You can also choose to only export a parameter when a range is explicitly brushed: ++ - If this setting is cleared (default), the parameter always has a value. When the parameter isn't brushed, the value is the full time range displayed in the chart. + - If this setting is selected, the parameter has no value before the user brushes the parameter. The value is only set after a user brushes the parameter. ++## Brushing in a metrics chart ++When you enable time brushing on a metrics chart, you can "brush" a time by dragging the mouse on the time chart. +++After the brush has stopped, the metrics chart zooms in to that range and exports the range as a time range parameter. +An icon on the toolbar in the upper-right corner is active to reset the time range back to its original, unzoomed time range. ++## Brushing in a query chart ++When you enable time brushing on a query chart, indicators appear that you can drag, or you can brush a range on the time chart. +++After the brush has stopped, the query chart shows that range as a time range parameter but won't zoom in. This behavior is different than the behavior of metrics charts. Because of the complexity of user-written queries, it might not be possible for workbooks to correctly update the range used by the query in the query content directly. If the query is using a time range parameter, it's possible to get this behavior by using a [global parameter](workbooks-parameters.md#global-parameters) instead. ++An icon on the toolbar in the upper-right corner is active to reset the time range back to its original, un-zoomed time range. |
azure-monitor | Workbooks Traffic Lights | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-traffic-lights.md | + + Title: Azure Workbooks visual indicators and icons +description: Learn about all how to create visual indicators and icons, such as traffic lights in Azure Monitor Workbooks. ++++ Last updated : 01/08/2024+++# Visual indicators and icons ++You can summarize status by using a simple visual indication instead of presenting the full range of data values. For example, you can categorize your computers by CPU utilization as cold, warm, or hot and categorize performance as satisfied, tolerated, or frustrated. You can use an indicator or icon that represents the status next to the underlying metric. +++## Create a traffic light icon ++The following example shows how to set up a traffic light icon per computer based on the CPU utilization metric. ++1. [Create a new empty workbook](workbooks-create-workbook.md). +1. [Add a parameter](workbooks-create-workbook.md#add-parameters), make it a [time range parameter](workbooks-time.md), and name it **TimeRange**. +1. Select **Add query** to add a log query control to the workbook. +1. For **Query type**, select `Logs`, and for **Resource type**, select `Log Analytics`. Select a Log Analytics workspace in your subscription that has VM performance data as a resource. +1. In the query editor, enter: ++ ``` + Perf + | where ObjectName == 'Processor' and CounterName == '% Processor Time' + | summarize Cpu = percentile(CounterValue, 95) by Computer + | join kind = inner (Perf + | where ObjectName == 'Processor' and CounterName == '% Processor Time' + | make-series Trend = percentile(CounterValue, 95) default = 0 on TimeGenerated from {TimeRange:start} to {TimeRange:end} step {TimeRange:grain} by Computer + ) on Computer + | project-away Computer1, TimeGenerated + | order by Cpu desc + ``` ++1. Set **Visualization** to `Grid`. +1. Select **Column Settings**. +1. In the **Columns** section, set: + - **Cpu** + - **Column renderer**: `Thresholds` + - **Custom number formatting**: `checked` + - **Units**: `Percentage` + - **Threshold settings** (last two need to be in order): + - **Icon**: `Success`, **Operator**: `Default` + - **Icon**: `Critical`, **Operator**: `>`, **Value**: `80` + - **Icon**: `Warning`, **Operator**: `>`, **Value**: `60` + - **Trend** + - **Column renderer**: `Spark line` + - **Color palette**: `Green to Red` + - **Minimum value**: `60` + - **Maximum value**: `80` +1. Select **Save and Close** to commit the changes. +++You can also pin this grid to a dashboard by using **Pin to dashboard**. The pinned grid automatically binds to the time range in the dashboard. +++## Next Steps ++[Learn about the types of visualizations you can use to create rich visual reports with Azure Workbooks](workbooks-visualizations.md). |
azure-monitor | Workbooks Visualizations | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/visualize/workbooks-visualizations.md | Workbooks support these kinds of visual components: ## Next steps -[Get started with Azure Workbooks](workbooks-getting-started.md) +[Get started with Azure Workbooks](workbooks-overview.md) |
azure-monitor | Whats New | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-monitor/whats-new.md | Alerts|[Create or edit a metric alert rule](alerts/alerts-create-new-alert-rule. Application-Insights|[Add, modify, and filter OpenTelemetry](app/opentelemetry-add-modify.md)|Custom events code samples and instructions have been added to .NET Core / .NET tabs.| Application-Insights|[Migrate availability tests](app/availability-test-migration.md)|We've clarified the URL ping tests retirement statement. Migrate your URL ping tests as soon as possible using the PowerShell scripts provided in this article.| Application-Insights|[Enable Azure Monitor Application Insights Real User Monitoring](app/javascript-sdk.md)|Additional guidance has been added on when to use the npm package.|-Application-Insights|[Migrate to workspace-based Application Insights resources](app/convert-classic-resource.md)|We confirmed that migrating from classic to workspace-based resources doesn't introduce application downtime or restarts, and it does not change your existing instrumentation key or connection string.|" +Application-Insights|[Migrate to workspace-based Application Insights resources](app/convert-classic-resource.md)|We confirmed that migrating from classic to workspace-based resources doesn't introduce application downtime or restarts, and it does not change your existing instrumentation key or connection string.| Logs|[Correlate data in Azure Data Explorer and Azure Resource Graph with data in a Log Analytics workspace](logs/azure-monitor-data-explorer-proxy.md)|Explained how to query Azure Data Explorer external tables using the `adx("")` expression. | Logs|[Logs Ingestion API in Azure Monitor](logs/logs-ingestion-api-overview.md)|Updated Log Ingestion API version.| Profiler|[Profile production applications in Azure with Application Insights Profiler](profiler/profiler-overview.md)|Add support for Java profiler and link to docs from .NET profiler overview.| Containers|[Monitor Kubernetes clusters using Azure services and cloud native to Containers|[Monitor Azure Kubernetes Service (AKS)](/azure/aks/monitor-aks)|New article providing simplified introduction to monitoring AKS cluster.| Containers|[Container insights overview](containers/container-insights-overview.md)|Rewritten for to include new features and managed services.| Essentials|[Send Prometheus metrics to Log Analytics workspace with Container insights](containers/container-insights-prometheus-logs.md)|Updated to simplify article to only legacy method of sending Prometheus metrics to Log Analytics workspace.|-Essentials|[Collect Prometheus metrics from an AKS cluster](containers/prometheus-metrics-enable.md)|Updated to include additional onboarding methods.| +Essentials|[Collect Prometheus metrics from an AKS cluster](containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana)|Updated to include additional onboarding methods.| Essentials|[Azure Monitor managed service for Prometheus rule groups](essentials/prometheus-rule-groups.md)|Expanded "Limiting rules to a specific cluster"| Logs|[Enable cost optimization settings](containers/container-insights-cost-config.md)|Updated for portal updates and additional details on workspace tables.|-Logs|[Enable the ContainerLogV2 schema](containers/container-insights-logging-v2.md)|Updated configuration section.| +Logs|[Enable the ContainerLogV2 schema](containers/container-insights-logs-schema.md)|Updated configuration section.| Logs|[Manage access to Log Analytics workspaces](logs/manage-access.md)|Simplified flow for setting table-level access.| Logs|[Query data in Azure Data Explorer and Azure Resource Graph from Azure Monitor](logs/azure-monitor-data-explorer-proxy.md)|Azure Monitor now lets you query data in Azure Resource Graph from your Log Analytics workspace. | Application-Insights|[Application Insights logging with .NET](app/ilogger.md)|Up Application-Insights|[Azure Monitor overview](overview.md)|Updated Azure Monitor overview graphics along with related content.| Containers|[Metric alert rules in Container insights (preview)](containers/container-insights-metric-alerts.md)|Updated to indicate deprecation of metric alerts.| Containers|[Azure Monitor Container insights for Azure Arc-enabled Kubernetes clusters](containers/container-insights-enable-arc-enabled-clusters.md)|Added option for Azure Monitor Private Link Scope (AMPLS) + Proxy.|-Essentials|[Collect Prometheus metrics from an AKS cluster (preview)](essentials/prometheus-metrics-enable.md)|Enabled Windows metric collection metrics add-on.| +Essentials|[Collect Prometheus metrics from an AKS cluster (preview)](containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana)|Enabled Windows metric collection metrics add-on.| Essentials|[Query Prometheus metrics by using the API and PromQL](essentials/prometheus-api-promql.md)|New article: Query Azure Monitor workspaces by using REST and PromQL.| Essentials|[Configure remote write for Azure Monitor managed service for Prometheus by using Azure Active Directory authentication (preview)](essentials/prometheus-remote-write-active-directory.md)|Added Prometheus remote write Active Directory relabel.| Essentials|[Built-in policies for Azure Monitor](essentials/diagnostics-settings-policies-deployifnotexists.md)|Added new built-in policies to create diagnostic settings in Azure Monitor with deploy-if-not-exists defaults.| Containers|[Enable cost-optimization settings (preview)](containers/container-in Essentials|[Data collection transformations in Azure Monitor](essentials/data-collection-transformations.md)|Added section and sample for using transformations to send to multiple destinations.| Essentials|[Custom metrics in Azure Monitor (preview)](essentials/metrics-custom-overview.md)|Added reference to the limit of 64 KB on the combined length of all custom metrics names.| Essentials|[Azure monitoring REST API walkthrough](essentials/rest-api-walkthrough.md)|Refreshed REST API walkthrough.|-Essentials|[Collect Prometheus metrics from AKS cluster (preview)](essentials/prometheus-metrics-enable.md)|Added enabling Prometheus metric collection by using Azure Policy and Bicep.| +Essentials|[Collect Prometheus metrics from AKS cluster (preview)](containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana)|Added enabling Prometheus metric collection by using Azure Policy and Bicep.| Essentials|[Send Prometheus metrics to multiple Azure Monitor workspaces (preview)](essentials/prometheus-metrics-multiple-workspaces.md)|Updated sending metrics to multiple Azure Monitor workspaces.| General|[Analyze and visualize data](best-practices-analysis.md)|Revised the article about analyzing and visualizing monitoring data to provide a comparison of the different visualization tools and guide customers on when to choose each tool for their implementation. | Logs|[Tutorial: Send data to Azure Monitor Logs by using the REST API (Resource Manager templates)](logs/tutorial-logs-ingestion-api.md)|Made minor fixes and updated sample data.| Change-Analysis|[Scenarios for using Change Analysis in Azure Monitor](change/ch Change-Analysis|[Scenarios for using Change Analysis in Azure Monitor](change/change-analysis-query.md)|Merged two low-engagement docs into Visualizations article and removed from TOC.| Change-Analysis|[Scenarios for using Change Analysis in Azure Monitor](change/change-analysis-visualizations.md)|Merged two low-engagement docs into Visualizations article and removed from TOC.| Change-Analysis|[Track a web app outage by using Change Analysis](change/tutorial-outages.md)|Added new section on virtual network changes to the tutorial.|-Containers|[Azure Monitor container insights for Azure Kubernetes Service hybrid clusters (preview)](containers/container-insights-enable-provisioned-clusters.md)|New article.| +Containers|[Azure Monitor container insights for Azure Kubernetes Service hybrid clusters (preview)](containers/kubernetes-monitoring-enable.md?tabs=cli)|New article.| Containers|[Syslog collection with Container insights (preview)](containers/container-insights-syslog.md)|New article.| Essentials|[Query Prometheus metrics by using Azure Workbooks (preview)](essentials/prometheus-workbooks.md)|New article.| Essentials|[Azure Workbooks data sources](visualize/workbooks-data-sources.md)|Added section for Prometheus metrics.| Containers|[Enable Container insights for Azure Kubernetes Service cluster](cont Containers Prometheus|[Query logs from Container insights](containers/container-insights-log-query.md)|Updated to include log queries for Prometheus data.| Containers Prometheus|[Collect Prometheus metrics with Container insights](containers/container-insights-prometheus.md?tabs=cluster-wide)|Updated to include Azure Monitor managed service for Prometheus.| Essentials Prometheus|[Metrics in Azure Monitor](essentials/data-platform-metrics.md)|Updated to include Azure Monitor managed service for Prometheus.|-Essentials Prometheus|<ul> <li> [Azure Monitor workspace overview (preview)](essentials/azure-monitor-workspace-overview.md?tabs=azure-portal) </li><li> [Overview of Azure Monitor managed service for Prometheus (preview)](essentials/prometheus-metrics-overview.md) </li><li>[Rule groups in Azure Monitor managed service for Prometheus (preview)](essentials/prometheus-rule-groups.md)</li><li>[Remote-write in Azure Monitor managed service for Prometheus (preview)](essentials/prometheus-remote-write-managed-identity.md) </li><li>[Use Azure Monitor managed service for Prometheus (preview) as data source for Grafana](essentials/prometheus-grafana.md)</li><li>[Troubleshoot collection of Prometheus metrics in Azure Monitor (preview)](essentials/prometheus-metrics-troubleshoot.md)</li><li>[Default Prometheus metrics configuration in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-default.md)</li><li>[Scrape Prometheus metrics at scale in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-scale.md)</li><li>[Customize scraping of Prometheus metrics in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-configuration.md)</li><li>[Create, validate, and troubleshoot custom configuration file for Prometheus metrics in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-validate.md)</li><li>[Minimal Prometheus ingestion profile in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-configuration-minimal.md)</li><li>[Collect Prometheus metrics from AKS cluster (preview)](essentials/prometheus-metrics-enable.md)</li><li>[Send Prometheus metrics to multiple Azure Monitor workspaces (preview)](essentials/prometheus-metrics-multiple-workspaces.md) </li></ul> |New articles: Public preview of Azure Monitor managed service for Prometheus.| +Essentials Prometheus|<ul> <li> [Azure Monitor workspace overview (preview)](essentials/azure-monitor-workspace-overview.md?tabs=azure-portal) </li><li> [Overview of Azure Monitor managed service for Prometheus (preview)](essentials/prometheus-metrics-overview.md) </li><li>[Rule groups in Azure Monitor managed service for Prometheus (preview)](essentials/prometheus-rule-groups.md)</li><li>[Remote-write in Azure Monitor managed service for Prometheus (preview)](essentials/prometheus-remote-write-managed-identity.md) </li><li>[Use Azure Monitor managed service for Prometheus (preview) as data source for Grafana](essentials/prometheus-grafana.md)</li><li>[Troubleshoot collection of Prometheus metrics in Azure Monitor (preview)](essentials/prometheus-metrics-troubleshoot.md)</li><li>[Default Prometheus metrics configuration in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-default.md)</li><li>[Scrape Prometheus metrics at scale in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-scale.md)</li><li>[Customize scraping of Prometheus metrics in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-configuration.md)</li><li>[Create, validate, and troubleshoot custom configuration file for Prometheus metrics in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-validate.md)</li><li>[Minimal Prometheus ingestion profile in Azure Monitor (preview)](essentials/prometheus-metrics-scrape-configuration-minimal.md)</li><li>[Collect Prometheus metrics from AKS cluster (preview)](containers/kubernetes-monitoring-enable.md#enable-prometheus-and-grafana)</li><li>[Send Prometheus metrics to multiple Azure Monitor workspaces (preview)](essentials/prometheus-metrics-multiple-workspaces.md) </li></ul> |New articles: Public preview of Azure Monitor managed service for Prometheus.| Essentials Prometheus|[Azure Monitor managed service for Prometheus remote write - managed identity (preview)](./essentials/prometheus-remote-write-managed-identity.md)|Added information that verifies Prometheus remote write is working correctly.| Essentials|[Azure resource logs](./essentials/resource-logs.md)|Clarified which blob's logs are written to, and when.| Essentials|[Resource Manager template samples for Azure Monitor](resource-manager-samples.md?tabs=portal)|Added template deployment methods.| All references to unsupported versions of .NET and .NET CORE are scrubbed from A | Article | Description | |:|:|-| [Configure ContainerLogv2 schema (preview) for Container insights](containers/container-insights-logging-v2.md) | New article: Describes new schema for container logs. | +| [Configure ContainerLogv2 schema (preview) for Container insights](containers/container-insights-logs-schema.md) | New article: Describes new schema for container logs. | | [Enable Container insights](containers/container-insights-onboard.md) | Rewritten to improve clarity. | | [Resource Manager template samples for Container insights](containers/resource-manager-container-insights.md) | Added Bicep examples. | ### Insights |
azure-netapp-files | Azure Netapp Files Introduction | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-netapp-files/azure-netapp-files-introduction.md | Last updated 01/26/2023 -# What is Azure NetApp Files +# What is Azure NetApp Files? -Azure NetApp Files is an Azure native, first-party, enterprise-class, high-performance file storage service. It provides NAS volumes as a service for which you can create NetApp accounts, capacity pools, select service and performance levels, create volumes, and manage data protection. It allows you to create and manage high-performance, highly available, and scalable file shares, using the same protocols and tools that you're familiar with and enterprise applications rely on on-premises. Azure NetApp Files supports SMB and NFS protocols and can be used for various use cases such as file sharing, home directories, databases, high-performance computing and more. Additionally, it also provides built-in availability, data protection and disaster recovery capabilities. +Azure NetApp Files is an Azure native, first-party, enterprise-class, high-performance file storage service. It provides volumes as a service for which you can create NetApp accounts, capacity pools, select service and performance levels, create volumes, and manage data protection. It allows you to create and manage high-performance, highly available, and scalable file shares, using the same protocols and tools that you're familiar with and enterprise applications rely on on-premises. Azure NetApp Files supports SMB and NFS protocols and can be used for various use cases such as file sharing, home directories, databases, high-performance computing and more. Additionally, it also provides built-in availability, data protection and disaster recovery capabilities. ## High performance |
azure-netapp-files | Configure Customer Managed Keys | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-netapp-files/configure-customer-managed-keys.md | Azure NetApp Files customer-managed keys is supported for the following regions: * Japan East * Japan West * Korea Central+* Korea South * North Central US * North Europe * Norway East |
azure-netapp-files | Cool Access Introduction | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-netapp-files/cool-access-introduction.md | Standard storage with cool access is supported for the following regions: * Australia East * Australia Southeast * Brazil South +* Brazil Southeast * Canada Central * Canada East * Central India Standard storage with cool access is supported for the following regions: * France Central * North Central US * North Europe +* Southeast Asia * Switzerland North * Switzerland West * UAE North +* West US ## Effects of cool access on data |
azure-netapp-files | Manage Availability Zone Volume Placement | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-netapp-files/manage-availability-zone-volume-placement.md | ms.assetid: na-+ Last updated 01/13/2023 |
azure-netapp-files | Terraform Manage Volume | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-netapp-files/terraform-manage-volume.md | ms.assetid: na+ Last updated 12/20/2023 The following instructions are a high-level overview of the steps required to up * [Update Terraform-Managed Azure NetApp Files Volume Network Feature from Basic to Standard](configure-network-features.md#update-terraform-managed-azure-netapp-files-volume-from-basic-to-standard) * [Populate Availability Zone for Terraform-Managed Azure NetApp Files Volume](manage-availability-zone-volume-placement.md#populate-availability-zone-for-terraform-managed-volumes)-* [Managing Azure NetApp Files preview features with Terraform Cloud and AzAPI Provider](https://techcommunity.microsoft.com/t5/azure-architecture-blog/managing-azure-netapp-files-preview-features-with-terraform/ba-p/3657714) +* [Managing Azure NetApp Files preview features with Terraform Cloud and AzAPI Provider](https://techcommunity.microsoft.com/t5/azure-architecture-blog/managing-azure-netapp-files-preview-features-with-terraform/ba-p/3657714) |
azure-relay | Relay Hybrid Connections Java Get Started | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-relay/relay-hybrid-connections-java-get-started.md | Title: Azure Relay Hybrid Connections - HTTP requests in Java description: Write a Java console application for Azure Relay Hybrid Connections HTTP requests. Last updated 01/04/2024-+ # Get started with Relay Hybrid Connections HTTP requests in Java |
azure-vmware | Concepts Private Clouds Clusters | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-vmware/concepts-private-clouds-clusters.md | Title: Concepts - Private clouds and clusters description: Understand the key capabilities of Azure VMware Solution software-defined data centers and VMware vSphere clusters. Previously updated : 12/20/2023 Last updated : 1/8/2024 Azure VMware Solution monitors the following conditions on the host: > [!NOTE] > Azure VMware Solution tenant admins must not edit or delete the previously defined VMware vCenter Server alarms because they are managed by the Azure VMware Solution control plane on vCenter Server. These alarms are used by Azure VMware Solution monitoring to trigger the Azure VMware Solution host remediation process. -## Backup and restoration +## Backup and restore -Private cloud vCenter Server and NSX-T Data Center configurations are on an hourly backup schedule. Backups are kept for three days. If you need to restore from a backup, open a [support request](https://rc.portal.azure.com/#create/Microsoft.Support) in the Azure portal to request restoration. +Azure VMware Solution private cloud vCenter Server, NSX-T Data Center, and HCX Manager (if enabled) configurations are on a daily backup schedule. Backups are kept for three days. If you need to restore from a backup, open a [support request](https://rc.portal.azure.com/#create/Microsoft.Support) in the Azure portal to request restoration. Azure VMware Solution continuously monitors the health of both the physical underlay and the VMware Solution components. When Azure VMware Solution detects a failure, it takes action to repair the failed components. |
azure-vmware | Connect Multiple Private Clouds Same Region | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-vmware/connect-multiple-private-clouds-same-region.md | Title: Connect multiple Azure VMware Solution private clouds in the same region description: Learn how to create a network connection between two or more Azure VMware Solution private clouds located in the same region. Previously updated : 12/22/2023 Last updated : 1/8/2024 -You can connect a private cloud to multiple private clouds, and the connections are nontransitive. For example, if _private cloud 1_ is connected to _private cloud 2_, and _private cloud 2_ is connected to _private cloud 3_, private clouds 1 and 3 wouldn't communicate until they were directly connected. +You can connect a private cloud to multiple private clouds, and the connections are nontransitive. For example, if _private cloud A_ is connected to _private cloud B_, and _private cloud B_ is connected to _private cloud C_, private clouds A and B wouldn't communicate until they were directly connected. You can only connect private clouds in the same region. To connect private clouds in different regions, [use ExpressRoute Global Reach](tutorial-expressroute-global-reach-private-cloud.md) to connect them in the same way you connect your private cloud to your on-premises circuit. The Azure VMware Solution Interconnect feature is available in all regions. - Routed IP address space in each cloud is unique and doesn't overlap >[!NOTE]->The **AVS interconnect** feature doesn't check for overlapping IP space the way native Azure vNet peering does before creating the peering. Therefore, it's your responsibility to ensure that there isn't overlap between the private clouds. +>The **AVS Interconnect** feature doesn't check for overlapping IP space the way native Azure vNet peering does before creating the peering. Therefore, it's your responsibility to ensure that there isn't overlap between the private clouds. >->In Azure VMware Solution environments, it's possible to configure non-routed, overlapping IP deployments on NSX segments that aren't routed to Azure. These don't cause issues with the AVS Interconnect feature, as it only routes between the NSX-T Data Center T0 gateway on each private cloud. -+>In Azure VMware Solution environments, it's possible to configure non-routed, overlapping IP deployments on NSX segments that aren't routed to Azure. These don't cause issues with the AVS Interconnect feature, as it only routes between the NSX-T Data Center T0 gateway on each private cloud. ## Add connection between private clouds |
azure-vmware | Create Placement Policy | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/azure-vmware/create-placement-policy.md | Title: Create placement policy description: Learn how to create a placement policy in Azure VMware Solution to control the placement of virtual machines (VMs) on hosts within a cluster through the Azure portal. Previously updated : 12/07/2023 Last updated : 1/8/2024 #Customer intent: As an Azure service administrator, I want to control the placement of virtual machines on hosts within a cluster in my private cloud. -The placement policy feature is available in all Azure VMware Solution regions. -Placement policies let you control the placement of virtual machines (VMs) on hosts within a cluster through the Azure portal. -When you create a placement policy, it includes a DRS rule in the specified vSphere cluster. -It also includes other logic for interoperability with Azure VMware Solution operations. +The placement policy feature is available in all Azure VMware Solution regions. Placement policies let you control the placement of virtual machines (VMs) on hosts within a cluster through the Azure portal. When you create a placement policy, it includes a DRS rule in the specified vSphere cluster. It also includes other logic for interoperability with Azure VMware Solution operations. A placement policy has at least five required components: A placement policy has at least five required components: - **Virtual machine** - Defines the VMs and hosts for the policy. Depending on the type of rule you create, your policy might require you to specify some number of VMs and hosts. For more information, see [Placement policy types](#placement-policy-types). - ## Prerequisite You must have _Contributor_ level access to the private cloud to manage placement policies. - ## Placement policy types ### VM-VM policies The assignment of hosts isn't required or permitted for this policy type. - **VM-VM Anti-Affinity** policies instruct DRS to try keeping the specified VMs apart from each other on separate hosts. It's useful in availability scenarios where a problem with one host doesn't affect multiple VMs within the same policy. - ### VM-Host policies **VM-Host** policies specify if selected VMs can run on selected hosts. To avoid interference with platform-managed operations such as host maintenance mode and host replacement, **VM-Host** policies in Azure VMware Solution are always preferential (also known as "should" rules). Accordingly, **VM-Host** policies [may not be honored in certain scenarios](https://docs.vmware.com/en/VMware-vSphere/6.7/com.vmware.vsphere.resmgmt.doc/GUID-793013E2-0976-43B7-9A00-340FA76859D0.html). For more information, see [Monitor the operation of a policy](#monitor-the-operation-of-a-policy). In addition to choosing a name and cluster for the policy, a **VM-Host** policy - **VM-Host Anti-Affinity** policies instruct DRS to try running the specified VMs on hosts other than the ones defined. - ## Considerations -### Cluster scale in +### Cluster scale-in Azure VMware Solution attempts to prevent certain DRS rule violations from occurring when performing cluster scale-in operations. You can't remove the last host from a VM-Host policy. However, if you need to re You can't have a VM-VM Anti Affinity policy with more VMs than the number of hosts in a cluster. If removing a host results in fewer hosts in the cluster than VMs, you receive an error preventing the operation. You can remediate it by first removing VMs from the rule and then removing the host from the cluster. - ### Rule conflicts If DRS rule conflicts are detected when you create a VM-VM policy, it results in that policy being created in a disabled state following standard [VMware DRS Rule behavior](https://docs.vmware.com/en/VMware-vSphere/6.7/com.vmware.vsphere.resmgmt.doc/GUID-69C738B6-5FC8-4189-9CB5-DD90A5A05979.html). For more information on viewing rule conflicts, see [Monitor the operation of a policy](#monitor-the-operation-of-a-policy). -- ## Create a placement policy There's no defined limit to the number of policies that you create. However, the more placement constraints you create, the more challenging it is for vSphere DRS to effectively move virtual machines within the cluster and provide the resources needed by the workloads. Make sure to review the requirements for the [policy type](#placement-policy-typ >You may also select the Cluster from the Placement Policy overview pane and then select **Create**. > -- 1. Provide a descriptive name, select the policy type, and select the cluster where the policy is created. Then select **Enabled**. >[!WARNING] >If you disable the policy, then the policy and the underlying DRS rule are created, but the policy actions are ignored until you enable the policy. - 1. If you selected **VM-Host affinity** or **VM-Host anti-affinity** as the type, select **+ Add hosts** and the hosts to include in the policy. You can select multiple hosts. >[!NOTE] Make sure to review the requirements for the [policy type](#placement-policy-typ > 1. Select **+ Add virtual machine** and the VMs to include in the policy. You can select multiple VMs.-- + >[!NOTE] >The select hosts pane shows how many VM-Host policies are associated with the host and the total number of VMs contained in those associated policies. Make sure to review the requirements for the [policy type](#placement-policy-typ :::image type="content" source="media/placement-policies/create-placement-policy-8.png" alt-text="Screenshot showing the placement policy as Enabled after it gets created." lightbox="media/placement-policies/create-placement-policy-8.png"::: - ## Edit a placement policy You can change the state of a policy, add a new resource, or unassign an existing resource. You can change the state of a policy to **Enabled** or **Disabled**. 1. Review the changes and select **Update policy**. If you want to make changes, select **Back: Basics**. - ### Update the resources in a policy You can add new resources, such as a VM or a host, to a policy or remove existing ones. To add a new resource, select **Edit virtual machine** or **Edit host**, select 1. Review the changes and select **Update policy**. If you want to make changes, select **Back : Basics**. - ## Delete a policy You can delete a placement policy and its corresponding DRS rule. Manual vMotion of the VM and automatic initial placement of the VM continues to ### Are placement policies the same as DRS affinity rules? Yes, and no. While vSphere DRS implements the current set of policies, we simplified the experience. Modifying VM groups and Host groups are a cumbersome operation, especially as hosts are ephemeral in nature and could be replaced in a cloud environment. As hosts are replaced in the vSphere inventory in an on-premises environment, the vSphere admin must modify the host group to ensure that the desired VM-Host placement constraints remain in effect. Placement policies in Azure VMware Solution update the Host groups when a host is rotated or changed. Similarly, if you scale in a cluster, the Host Group is automatically updated, as applicable. The automatic update eliminates the overhead of managing the Host Groups for the customer. +### As this is an existing functionality available in vCenter Server, why can't I use it directly? -### As this is an existing functionality available in vCenter, why can't I use it directly? +Azure VMware Solution provides a private cloud in Azure. In this managed VMware solution infrastructure, Microsoft manages the clusters, hosts, datastores, and distributed virtual switches in the private cloud. At the same time, the tenant is responsible for managing the workloads deployed on the private cloud. As a result, the tenant administering the private cloud doesn't have the [same set of privileges](concepts-identity.md) as available to the VMware solution administrator in an on-premises deployment. -Azure VMware Solution provides a VMware private cloud in Azure. In this managed VMware infrastructure, Microsoft manages the clusters, hosts, datastores, and distributed virtual switches in the private cloud. At the same time, the tenant is responsible for managing the workloads deployed on the private cloud. As a result, the tenant administering the private cloud doesn't have the [same set of privileges](concepts-identity.md) as available to the VMware administrator in an on-premises deployment. --Further, the lack of the desired granularity in the vSphere privileges presents some challenges when managing the placement of the workloads on the private cloud. For example, vSphere DRS rules commonly used on-premises to define affinity and anti-affinity rules can't be used as-is in an Azure VMware Solution environment, as some of those rules can block day-to-day operation the private cloud. Placement Policies provides a way to define those rules using the Azure VMware Solution portal, thereby circumventing the need to use DRS rules. Coupled with a simplified experience, Placement Policies ensure the rules don't impact the day-to-day infrastructure maintenance and operation activities. +Further, the lack of the desired granularity in the vSphere privileges presents some challenges when managing the placement of the workloads on the private cloud. For example, vSphere DRS rules commonly used on-premises to define affinity and anti-affinity rules can't be used as-is in an Azure VMware Solution environment, as some of those rules can block day-to-day operation the private cloud. Placement Policies provides a way to define those rules using the Azure portal, thereby circumventing the need to use DRS rules. Coupled with a simplified experience, Placement Policies ensure the rules don't impact the day-to-day infrastructure maintenance and operation activities. ### What is the difference between the VM-Host affinity policy and Restrict VM movement? The VM-Host **MUST** rules aren't supported because they block maintenance opera VM-Host **SHOULD** rules are preferential rules, where vSphere DRS tries to accommodate the rules to the extent possible. Occasionally, vSphere DRS may vMotion VMs subjected to the VM-Host **SHOULD** rules to ensure that the workloads get the resources they need. It's a standard vSphere DRS behavior, and the Placement policies feature doesn't change the underlying vSphere DRS behavior. If you create conflicting rules, those conflicts can show up on the vCenter Server, and the newly defined rules might not take effect. It's a standard vSphere DRS behavior, the logs for which can be observed in the vCenter Server.- |
backup | Backup Azure Database Postgresql Support Matrix | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/backup/backup-azure-database-postgresql-support-matrix.md | You can use [Azure Backup](./backup-overview.md) to protect Azure Database for P ## Supported regions -Azure Database for PostgreSQL server backup is available in the following regions: --East US, East US 2, Central US, South Central US, West US, West US 2, West Central US, Brazil South, Canada Central, North Europe, West Europe, UK South, UK West, Germany West Central, Switzerland North, Switzerland West, East Asia, Southeast Asia, Japan East, Japan West, Korea Central, Korea South, India Central, Australia East, Australia Central, Australia Central 2, UAE North +Azure Database for PostgreSQL server backup is available in all regions, except for Germany Central (Sovereign), Germany Northeast (Sovereign) and China regions. ## Support scenarios |
cdn | Cdn Features | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cdn/cdn-features.md | -Azure Content Delivery Network (CDN) includes four products: +Azure Content Delivery Network (CDN) includes three products: * **Azure CDN Standard from Microsoft** * **Azure CDN Standard from Edgio (formerly Verizon)** |
communication-services | Call Automation Ai | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/communication-services/samples/call-automation-ai.md | Last updated 12/08/2023 -+ zone_pivot_groups: acs-js-csharp-java-python |
communication-services | Meeting Interop Features Inline Image | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/communication-services/tutorials/chat-interop/meeting-interop-features-inline-image.md | Last updated 03/27/2023 -+ zone_pivot_groups: acs-js-csharp |
container-apps | Azure Resource Manager Api Spec | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/container-apps/azure-resource-manager-api-spec.md | |
container-apps | Enable Dapr | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/container-apps/enable-dapr.md | description: Learn more about enabling Dapr on your Azure Container App service -+ Last updated 12/18/2023 |
container-apps | Health Probes | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/container-apps/health-probes.md | -Azure Container Apps Health probes are based on [Kubernetes health probes](https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/). These probes allow the Container Apps runtime to regularly inspect the status of your container apps. +Azure Container Apps health probes allow the Container Apps runtime to regularly inspect the status of your container apps. You can set up probes using either TCP or HTTP(S) exclusively. |
container-registry | Container Registry Auth Kubernetes | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/container-registry/container-registry-auth-kubernetes.md | Title: Authenticate with an Azure container registry using a Kubernetes pull secret description: Learn how to provide a Kubernetes cluster with access to images in your Azure container registry by creating a pull secret using a service principal -+ |
container-registry | Container Registry Auth Service Principal | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/container-registry/container-registry-auth-service-principal.md | Title: Authenticate with service principal description: Provide access to images in your private container registry by using a Microsoft Entra service principal. -+ |
container-registry | Container Registry Auto Purge | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/container-registry/container-registry-auto-purge.md | Title: Purge tags and manifests description: Use a purge command to delete multiple tags and manifests from an Azure container registry based on age and a tag filter, and optionally schedule purge operations. + Last updated 10/31/2023 |
container-registry | Container Registry Configure Conditional Access | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/container-registry/container-registry-configure-conditional-access.md | Title: Configure conditional access to your Azure Container Registry. description: Learn how to configure conditional access to your registry by using Azure CLI and Azure portal. + Last updated 11/02/2023- # Conditional Access policy for Azure Container Registry Create a Conditional Access policy and assign your test group of users as follow > [!div class="nextstepaction"] > [Azure Policy definitions](../governance/policy/concepts/definition-structure.md) and [effects](../governance/policy/concepts/effects.md). >[Common access concerns that Conditional Access policies can help with](../active-directory/conditional-access/concept-conditional-access-policy-common.md).-> [Conditional Access policy components](../active-directory/conditional-access/concept-conditional-access-policies.md). +> [Conditional Access policy components](../active-directory/conditional-access/concept-conditional-access-policies.md). |
container-registry | Container Registry Disable Authentication As Arm | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/container-registry/container-registry-disable-authentication-as-arm.md | Title: Disable authentication as ARM template description: "Disabling azureADAuthenticationAsArmPolicy will force the registry to use ACR audience token." + Last updated 10/31/2023- # Disable authentication as ARM template |
container-registry | Container Registry Troubleshoot Access | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/container-registry/container-registry-troubleshoot-access.md | Related links: * [Configure rules to access an Azure container registry behind a firewall](container-registry-firewall-access-rules.md) * [HTTP/HTTPS proxy configuration](https://docs.docker.com/config/daemon/systemd/#httphttps-proxy)-* [Geo-replicationin Azure Container Registry](container-registry-geo-replication.md) +* [Geo-replication in Azure Container Registry](container-registry-geo-replication.md) * [Monitor Azure Container Registry](monitor-service.md) ### Configure public access to registry |
cosmos-db | Concepts Limits | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/concepts-limits.md | The actual minimum RU/s may vary depending on your account configuration. You ca #### Minimum throughput on container -To estimate the minimum throughput required of a container with manual throughput, find the maximum of: +**Manual throughput** ++To estimate the minimum RU/s required of a container with manual throughput, find the maximum of: * 400 RU/s * Current storage in GB * 1 RU/s To estimate the minimum throughput required of a container with manual throughpu For example, you have a container provisioned with 400 RU/s and 0-GB storage. You increase the throughput to 50,000 RU/s and import 20 GB of data. The minimum RU/s is now `MAX(400, 20 * 1 RU/s per GB, 50,000 RU/s / 100)` = 500 RU/s. Over time, the storage grows to 2000 GB. The minimum RU/s is now `MAX(400, 2000 * 1 RU/s per GB, 50,000 / 100)` = 2000 RU/s. +**Autoscale throughput** ++To estimate the minimum autoscale max RU/s required of a container with autoscale throughput, find the maximum of: ++* 1000 RU/s +* Current storage in GB * 10 RU/s +* Highest RU/s ever provisioned on the container / 10 ++For example, you have a container provisioned with 1000 RU/s and 0-GB storage. You increase the throughput to 50,000 RU/s and import 20 GB of data. The minimum max RU/s is now `MAX(1000, 20 * 10 RU/s per GB, 50,000 RU/s / 10)` = 5000 RU/s. Over time, the storage grows to 2000 GB. The minimum max RU/s is now `MAX(1000, 2000 * 10 RU/s per GB, 50,000 / 10)` = 20,000 RU/s. + #### Minimum throughput on shared throughput database -To estimate the minimum throughput required of a shared throughput database with manual throughput, find the maximum of: +**Manual throughput** ++To estimate the minimum RU/s required of a shared throughput database with manual throughput, find the maximum of: * 400 RU/s * Current storage in GB * 1 RU/s * Highest RU/s ever provisioned on the database / 100 * 400 + MAX(Container count - 25, 0) * 100 RU/s -For example, you have a database provisioned with 400 RU/s, 15 GB of storage, and 10 containers. The minimum RU/s is `MAX(400, 15 * 1 RU/s per GB, 400 / 100, 400 + 0 )` = 400 RU/s. If there were 30 containers in the database, the minimum RU/s would be `400 + MAX(30 - 25, 0) * 100 RU/s` = 900 RU/s. +For example, you have a database provisioned with 400 RU/s, 15 GB of storage, and 10 containers. The minimum RU/s is `MAX(400, 15 * 1 RU/s per GB, 400 / 100, 400 + 0 )` = 400 RU/s. If there were 30 containers in the database, the minimum RU/s would be `400 + MAX(30 - 25, 0) * 100 RU/s` = 900 RU/s. -In summary, here are the minimum provisioned RU limits when using manual throughput. +**Autoscale throughput** -| Resource | Limit | -| | | -| Minimum RUs per container ([dedicated throughput provisioned mode with manual throughput](./resource-model.md#azure-cosmos-db-containers)) | 400 | -| Minimum RUs per database ([shared throughput provisioned mode with manual throughput](./resource-model.md#azure-cosmos-db-containers)) | 400 RU/s for first 25 containers. | +To estimate the minimum autoscale max RU/s required of a shared throughput database with autoscale throughput, find the maximum of: ++* 1000 RU/s +* Current storage in GB * 10 RU/s +* Highest RU/s ever provisioned on the database / 10 +* 1000 + MAX(Container count - 25, 0) * 1000 RU/s ++For example, you have a database provisioned with 1000 RU/s, 15 GB of storage, and 10 containers. The minimum max RU/s for autoscale database is `MAX(1000, 15 * 10 RU/s per GB, 1000 / 10, 1000 + 0 )` = 1000 RU/s. If there were 30 containers in the database, the minimum max RU/s would be `1000 + MAX(30 - 25, 0) * 1000 RU/s` = 5000 RU/s. + ++In summary, here are the minimum provisioned RU limits when using provisioned throughput. ++| Provisioning Type | Resource | Limit | +| | | | +| Manual throughput | Minimum RUs per container ([dedicated throughput provisioned mode with manual throughput](./set-throughput.md#set-throughput-on-a-container)) | 400 | +| Manual throughput | Minimum RUs per database ([shared throughput provisioned mode with manual throughput](./set-throughput.md#set-throughput-on-a-database) | 400 RU/s for first 25 containers. | +| Autoscale throughput | Minimum max RUs per container ([dedicated throughput provisioned mode with autoscale throughput](./provision-throughput-autoscale.md#how-autoscale-provisioned-throughput-works)) | 1000 | +| Autoscale throughput | Minimum max RUs per database ([shared throughput provisioned mode with autoscale throughput](./provision-throughput-autoscale.md#how-autoscale-provisioned-throughput-works)) | 1000 RU/s for first 25 containers. | Azure Cosmos DB supports programmatic scaling of throughput (RU/s) per container or database via the SDKs or portal. |
cosmos-db | Emulator Release Notes | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/emulator-release-notes.md | Last updated 09/11/2023 The Azure Cosmos DB emulator is updated at a regular cadence with release notes provided in this article. > [!div class="nextstepaction"]-> [Download latest version (``2.14.12``)](https://aka.ms/cosmosdb-emulator) +> [Download latest version (``2.14.16``)](https://aka.ms/cosmosdb-emulator) ## Supported versions Only the most recent version of the Azure Cosmos DB emulator is actively supported. -## Latest version ``2.14.12`` +## Latest version ``2.14.16`` -> *Released March 20, 2023* +> *Released January 8, 2024* -- This release fixes an issue impacting Gremlin and Table endpoint API types. Prior to this fix a client application fails with a 500 status code when trying to connect to the public emulator's endpoint.+- This release fixes an issue which was causing emulator to bind with `loopback` instead of `public interface` even after passing /AllowNetworkAccess command line option. ## Previous releases > [!WARNING] > Previous versions of the emulator are not supported by the product group. +### ``2.14.12`` (March 20, 2023) ++- This release fixes an issue impacting Gremlin and Table endpoint API types. Prior to this fix a client application fails with a 500 status code when trying to connect to the public emulator's endpoint. + ### ``2.14.11`` (January 27, 2023) - This release updates the Azure Cosmos DB Emulator background services to match the latest online functionality of the Azure Cosmos DB. |
cosmos-db | How Pricing Works | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/how-pricing-works.md | The pricing model of Azure Cosmos DB simplifies the cost management and planning - **Serverless**: In [serverless](serverless.md) mode, you don't have to provision any throughput when creating resources in your Azure Cosmos DB account. At the end of your billing period, you get billed for the number of Request Units that has been consumed by your database operations. -- **Storage**: You're billed a flat rate for the total amount of storage (in GBs) consumed by your data and indexes for a given hour. Storage is billed on a consumption basis, so you don't have to reserve any storage in advance. You're billed only for the storage you consume.+- **Storage**: You're billed a flat rate for the total amount of storage (in GBs) consumed by your data and indexes for a given hour. Storage is billed on a consumption basis, so you don't have to reserve any storage in advance. You're billed only for the storage you consume. The smallest amount of data billed for any non empty container is 1 GB. The pricing model in Azure Cosmos DB is consistent across all APIs. For more information, see the [Azure Cosmos DB pricing page](https://azure.microsoft.com/pricing/details/cosmos-db/), [Understanding your Azure Cosmos DB bill](understand-your-bill.md) and [How Azure Cosmos DB pricing model is cost-effective for customers](total-cost-ownership.md). |
cosmos-db | How To Private Link | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/mongodb/vcore/how-to-private-link.md | - - ignite-2023 + Last updated 11/01/2023 # CustomerIntent: As a security administrator, I want to use Azure Private Link so that I can ensure that database connections occur over privately-managed virtual network endpoints. |
cosmos-db | Bulk Executor Java | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/nosql/bulk-executor-java.md | Currently, the bulk executor library is supported only by Azure Cosmos DB for No - On Ubuntu, you can run `apt-get install maven` to install Maven. -* Create an Azure Cosmos DB for NoSQL account by using the steps described in the [create database account](quickstart-java.md#create-a-database-account) section of the Java quickstart article. +* Create an Azure Cosmos DB for NoSQL account by using the steps described in the [create database account](quickstart-java.md) section of the Java quickstart article. ## Clone the sample application |
cosmos-db | Client Metrics Java | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/nosql/client-metrics-java.md | + + Title: Use Micrometer metrics for Java SDK in Azure Cosmos DB +description: Learn how to consume Micrometer metrics in the Java SDK for Azure Cosmos DB. +++++ Last updated : 12/14/2023+++# Micrometer metrics for Java ++The [Java SDK for Azure Cosmos DB](samples-java.md) implements client metrics using [Micrometer](https://micrometer.io/) for instrumentation in popular observability systems like [Prometheus](https://prometheus.io/). This article includes instructions and code snippets for scraping metrics into Prometheus, taken from [this sample](https://github.com/Azure-Samples/azure-cosmos-java-sql-api-samples/blob/main/src/main/jav). ++## Consume metrics from Prometheus ++You can download prometheus from [here](https://prometheus.io/download/). To consume Micrometer metrics in the Java SDK for Azure Cosmos DB using Prometheus, first ensure you have imported the required libraries for registry and client: ++```xml +<dependency> + <groupId>io.micrometer</groupId> + <artifactId>micrometer-registry-prometheus</artifactId> + <version>1.6.6</version> +</dependency> ++<dependency> + <groupId>io.prometheus</groupId> + <artifactId>simpleclient_httpserver</artifactId> + <version>0.5.0</version> +</dependency> +``` ++In your application, provide the prometheus registry to the telemetry config. Notice that you can set various diagnostic thresholds, which will help to limit metrics consumed to the ones you are most interested in: ++[!code-java[](~/azure-cosmos-java-sql-api-samples/src/main/java/com/azure/cosmos/examples/prometheus/async/CosmosClientMetricsQuickStartAsync.java?name=ClientMetricsConfig)] ++Start local HttpServer server to expose the meter registry metrics to Prometheus: ++[!code-java[](~/azure-cosmos-java-sql-api-samples/src/main/java/com/azure/cosmos/examples/prometheus/async/CosmosClientMetricsQuickStartAsync.java?name=PrometheusTargetServer)] ++Ensure you pass `clientTelemetryConfig` when creating your `CosmosClient`: ++[!code-java[](~/azure-cosmos-java-sql-api-samples/src/main/java/com/azure/cosmos/examples/prometheus/async/CosmosClientMetricsQuickStartAsync.java?name=CosmosClient)] +++When adding the endpoint for your application client to `prometheus.yml`, add the domain name and port to "targets". For example, if prometheus is running on the same server as your app client, you can add `localhost:8080` to `targets` as below: ++```yml +scrape_configs: + # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config. + - job_name: "prometheus" ++ # metrics_path defaults to '/metrics' + # scheme defaults to 'http'. ++ static_configs: + - targets: ["localhost:9090", "localhost:8080"] +``` ++Now you can consume metrics from Prometheus: ++++## Next steps ++- [Monitoring Azure Cosmos DB data reference](../monitor-reference.md) +- [Monitoring Azure resources with Azure Monitor](../../azure-monitor//essentials//monitor-azure-resource.md) |
cosmos-db | Distribute Throughput Across Partitions | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/nosql/distribute-throughput-across-partitions.md | description: Learn how to redistribute throughput across partitions (preview) -+ Last updated 12/18/2023 |
cosmos-db | How To Delete By Partition Key | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/nosql/how-to-delete-by-partition-key.md | Update your Azure Cosmos DB account to enable "Delete by partition key" feature $capabilities = ($cosmosdb | ConvertFrom-Json).capabilities ``` - Step 3: Add "Delete items by partition key" capability in the list of capabilities if it doesn't exist already. - >!Note - The list of capabilities must always specify all capabilities that you want to enable, inclusively. This includes capabilities that are already enabled for the account that you want to keep. + > [!NOTE] + > The list of capabilities must always specify all capabilities that you want to enable, inclusively. This includes capabilities that are already enabled for the account that you want to keep. ```azurecli-interactive $capabilities += $DeleteByPk |
cosmos-db | Quickstart Dotnet | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/nosql/quickstart-dotnet.md | Title: Quickstart - Client library for .NET + Title: Quickstart - .NET client library -description: Deploy a .NET web application to manage Azure Cosmos DB for NoSQL account resources in this quickstart. +description: Deploy a .NET web application that uses the client library to interact with Azure Cosmos DB for NoSQL data in this quickstart. + ms.devlang: csharp- Previously updated : 10/24/2023--zone_pivot_groups: azure-cosmos-db-quickstart-path -# CustomerIntent: As a developer, I want to learn the basics of the .NET client library so that I can build applications with Azure Cosmos DB for NoSQL. + Last updated : 01/08/2024+zone_pivot_groups: azure-cosmos-db-quickstart-env +# CustomerIntent: As a developer, I want to learn the basics of the .NET library so that I can build applications with Azure Cosmos DB for NoSQL. -# Quickstart: Azure Cosmos DB for NoSQL client library for .NET +# Quickstart: Azure Cosmos DB for NoSQL library for .NET [!INCLUDE[NoSQL](../includes/appliesto-nosql.md)] -Get started with the Azure Cosmos DB client library for .NET to create databases, containers, and items within your account. Follow these steps to deploy a sample application and explore the code. In this quickstart, you use the Azure Developer CLI (`azd`) and the `Microsoft.Azure.Cosmos` library to connect to a newly created Azure Cosmos DB for NoSQL account. +Get started with the Azure Cosmos DB for NoSQL client library for .NET to query data in your containers and perform common operations on individual items. Follow these steps to deploy a minimal solution to your environment using the Azure Developer CLI. [API reference documentation](/dotnet/api/microsoft.azure.cosmos) | [Library source code](https://github.com/Azure/azure-cosmos-dotnet-v3) | [Package (NuGet)](https://www.nuget.org/packages/Microsoft.Azure.Cosmos) | [Azure Developer CLI](/azure/developer/azure-developer-cli/overview) ## Prerequisites -- An Azure account with an active subscription.- - No Azure subscription? You can [try Azure Cosmos DB free](../try-free.md) with no credit card required. -- [.NET 8.0](https://dotnet.microsoft.com/download/dotnet/8.0) +## Setting up +Deploy this project's development container to your environment. Then, use the Azure Developer CLI (`azd`) to create an Azure Cosmos DB for NoSQL account and deploy a containerized sample application. The sample application uses the client library to manage, create, read, and query sample data. -## Deploy the Azure Developer CLI template -Use the Azure Developer CLI (`azd`) to create an Azure Cosmos DB for NoSQL account and set up an Azure Container Apps web application. The sample application uses the client library for .NET to manage resources. --1. Start in an empty directory in the Azure Cloud Shell. -- > [!TIP] - > We recommend creating a new uniquely named directory within the fileshare folder (`~/clouddrive`). - > - > For example, this command will create a new directory and navigate to that directory: - > - > ```azurecli-interactive - > mkdir ~/clouddrive/cosmos-db-nosql-dotnet-quickstart - > - > cd ~/clouddrive/cosmos-db-nosql-dotnet-quickstart - > ``` --1. Initialize the Azure Developer CLI using `azd init` and the `cosmos-db-nosql-dotnet-quickstart` template. -- ```azurecli-interactive - azd init --template cosmos-db-nosql-dotnet-quickstart - ``` --1. During initialization, configure a unique environment name. -- > [!NOTE] - > The environment name will also be used as the target resource group name. --1. Deploy the Azure Cosmos DB account and other resources for this quickstart with `azd provision`. -- ```azurecli-interactive - azd provision - ``` --1. During the provisioning process, select your subscription and desired location. Wait for the provisioning process to complete. The process can take **approximately five minutes**. --1. Once the provisioning of your Azure resources is done, a link to the running web application is included in the output. -- ```output - View the running web application in Azure Container Apps: - <https://container-app-39423723798.redforest-xz89v7c.eastus.azurecontainerapps.io> - - SUCCESS: Your application was provisioned in Azure in 5 minutes 0 seconds. - ``` --1. Use the link in the console to navigate to your web application in the browser. -- :::image type="content" source="media/quickstart-dotnet/web-application.png" alt-text="Screenshot of the running web application."::: +[![Open in GitHub Codespaces](https://img.shields.io/static/v1?style=for-the-badge&label=GitHub+Codespaces&message=Open&color=brightgreen&logo=github)](https://codespaces.new/azure-samples/cosmos-db-nosql-dotnet-quickstart?template=false&quickstart=1&azure-portal=true) ::: zone-end --## Get the application code --Use the Azure Developer CLI (`azd`) to get the application code. The sample application uses the client library for .NET to manage resources. --1. Start in an empty directory. --1. Initialize the Azure Developer CLI using `azd init` and the `cosmos-db-nosql-dotnet-quickstart` template. -- ```azurecli - azd init --template cosmos-db-nosql-dotnet-quickstart - ``` --1. During initialization, configure a unique environment name. -- > [!NOTE] - > If you decide to deploy this application to Azure in the future, the environment name will also be used as the target resource group name. --## Create the API for NoSQL account --Use the Azure CLI (`az`) to create an API for NoSQL account. You can choose to create an account in your existing subscription, or try a free Azure Cosmos DB account. --### [Try Azure Cosmos DB free](#tab/try-free) --1. Navigate to the **Try Azure Cosmos DB free** homepage: <https://cosmos.azure.com/try/> --1. Sign-in using your Microsoft account. --1. In the list of APIs, select the **Create** button for the **API for NoSQL**. --1. Navigate to the newly created account by selecting **Open in portal**. --1. Record the account and resource group names for the API for NoSQL account. You use these values in later steps. --> [!IMPORTANT] -> If you are using a free account, you might need to change the default subscription in Azure CLI to the subscription ID used for the free account. -> -> ```azurecli -> az account set --subscription <subscription-id> -> ``` --### [Azure subscription](#tab/azure-subscription) --1. If you haven't already, sign in to the Azure CLI using the `az login` command. --1. Use `az group create` to create a new resource group in your subscription. -- ```azurecli - az group create \ - --name <resource-group-name> \ - --location <location> - ``` --1. Use the `az cosmosdb create` command to create a new API for NoSQL account with default settings. -- ```azurecli - az cosmosdb create \ - --resource-group <resource-group-name> \ - --name <account-name> \ - --locations regionName=<location> - ``` ----## Create the database and container --Use the Azure CLI to create the `cosmicworks` database and `products` container for the quickstart. -1. Create a new database with `az cosmosdb sql database create`. Set the name of the database to `comsicworks` and use autoscale throughput with a maximum of **1,000** RU/s. +[![Open in Dev Container](https://img.shields.io/static/v1?style=for-the-badge&label=Dev+Containers&message=Open&color=blue&logo=visualstudiocode)](https://vscode.dev/redirect?url=vscode://ms-vscode-remote.remote-containers/cloneInVolume?url=https://github.com/azure-samples/cosmos-db-nosql-dotnet-quickstart) - ```azurecli - az cosmosdb sql database create \ - --resource-group <resource-group-name> \ - --account-name <account-name> \ - --name "cosmicworks" \ - --max-throughput 1000 - ``` --1. Create a container named `products` within the `cosmicworks` database using `az cosmosdb sql container create`. Set the partition key path to `/category`. -- ```azurecli - az cosmosdb sql container create \ - --resource-group <resource-group-name> \ - --account-name <account-name> \ - --database-name "cosmicworks" \ - --name "products" \ - --partition-key-path "/category" - ``` -## Configure passwordless authentication -When developing locally with passwordless authentication, make sure the user account that connects to Cosmos DB is assigned a role with the correct permissions to perform data operations. Currently, Azure Cosmos DB for NoSQL doesn't include built-in roles for data operations, but you can create your own using the Azure CLI or PowerShell. +### Install the client library -1. Get the API for NoSQL endpoint for the account using `az cosmosdb show`. You'll use this value in the next step. +The client library is available through NuGet, as the `Microsoft.Azure.Cosmos` package. - ```azurecli - az cosmosdb show \ - --resource-group <resource-group-name> \ - --name <account-name> \ - --query "documentEndpoint" - ``` --1. Set the `AZURE_COSMOS_DB_NOSQL_ENDPOINT` environment variable using the .NET secret manager (`dotnet user-secrets`). Set the value to the API for NoSQL account endpoint recorded in the previous step. +1. Open a terminal and navigate to the `/src/web` folder. ```bash- dotnet user-secrets set "AZURE_COSMOS_DB_NOSQL_ENDPOINT" "<cosmos-db-nosql-endpoint>" --project ./src/web/Cosmos.Samples.NoSQL.Quickstart.Web.csproj - ``` --1. Create a JSON file named `role-definition.json`. Use this content to configure the role with the following permissions: -- - `Microsoft.DocumentDB/databaseAccounts/readMetadata` - - `Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/items/*` - - `Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/*` -- ```json - { - "RoleName": "Write to Azure Cosmos DB for NoSQL data plane", - "Type": "CustomRole", - "AssignableScopes": [ - "/" - ], - "Permissions": [ - { - "DataActions": [ - "Microsoft.DocumentDB/databaseAccounts/readMetadata", - "Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/items/*", - "Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/*" - ] - } - ] - } - ``` --1. Create a role using the `az role definition create` command. Name the role `Write to Azure Cosmos DB for NoSQL data plane` and ensure the role is scoped to the account level using `/`. Use the `role-definition.json` file you created in the previous step. -- ```azurecli - az cosmosdb sql role definition create \ - --resource-group <resource-group-name> \ - --account-name <account-name> \ - --body @role-definition.json - ``` --1. When the command is finished, it outputs an object that includes an `id` field. Record the value from the `id` field. You use this value in an upcoming step. -- > [!TIP] - > If you need to get the `id` again, you can use the `az cosmosdb sql role definition list` command: - > - > ```azurecli - > az cosmosdb sql role definition list \ - > --resource-group <resource-group-name> \ - > --account-name <account-name> \ - > --query "[?roleName == 'Write to Azure Cosmos DB for NoSQL data plane'].id" - > ``` - > --1. For local development, get your currently logged in **service principal id**. Record this value as you'll also use this value in the next step. -- ```azurecli - az ad signed-in-user show --query id + cd ./src/web ``` -1. Assign the role definition to your currently logged in user using `az cosmosdb sql role assignment create`. +1. If not already installed, install the `Microsoft.Azure.Cosmos` package using `dotnet add package`. - ```azurecli - az cosmosdb sql role assignment create \ - --resource-group <resource-group-name> \ - --account-name <account-name> \ - --scope "/" \ - --role-definition-id "<your-custom-role-definition-id>" \ - --principal-id "<your-service-principal-id>" + ```bash + dotnet add package Microsoft.Azure.Cosmos ``` -1. Run the .NET web application. +1. Also, install the `Azure.Identity` package if not already installed. ```bash- dotnet run --project ./src/web/Cosmos.Samples.NoSQL.Quickstart.Web.csproj + dotnet add package Azure.Identity ``` -1. Use the link in the console to navigate to your web application in the browser. +1. Open and review the **src/web/Cosmos.Samples.NoSQL.Quickstart.Web.csproj** file to validate that the `Microsoft.Azure.Cosmos` and `Azure.Identity` entries both exist. - :::image type="content" source="media/quickstart-dotnet/web-application.png" alt-text="Screenshot of the running web application."::: +## Object model +| Name | Description | +| | | +| <xref:Microsoft.Azure.Cosmos.CosmosClient> | This class is the primary client class and is used to manage account-wide metadata or databases. | +| <xref:Microsoft.Azure.Cosmos.Database> | This class represents a database within the account. | +| <xref:Microsoft.Azure.Cosmos.Container> | This class is primarily used to perform read, update, and delete operations on either the container or the items stored within the container. | +| <xref:Microsoft.Azure.Cosmos.PartitionKey> | This class represents a logical partition key. This class is required for many common operations and queries. | -## Walk through the .NET library code +## Code examples - [Authenticate the client](#authenticate-the-client) - [Get a database](#get-a-database) When developing locally with passwordless authentication, make sure the user acc - [Get an item](#read-an-item) - [Query items](#query-items) -The sample code in the Azure Develop CLI template creates a database named `cosmicworks` with a container named `products`. The `products` container is designed to contain product details such as name, category, quantity, and a sale indicator. Each product also contains a unique identifier. --For this sample, the container uses the `/category` property as a logical partition key. --The code blocks used to perform these operations in this sample are included in this section. You can also [browse the entire template's source](https://vscode.dev/github/azure-samples/cosmos-db-nosql-dotnet-quickstart) using Visual Studio Code for the Web. ### Authenticate the client -Application requests to most Azure services must be authorized. Using the <xref:Azure.Identity.DefaultAzureCredential> class provided by the <xref:Azure.Identity> client library and namespace is the recommended approach for implementing passwordless connections to Azure services in your code. --> [!IMPORTANT] -> You can also authorize requests to Azure services using passwords, connection strings, or other credentials directly. However, this approach should be used with caution. Developers must be diligent to never expose these secrets in an unsecure location. Anyone who gains access to the password or secret key is able to authenticate. `DefaultAzureCredential` offers improved management and security benefits over the account key to allow passwordless authentication. -`DefaultAzureCredential` supports multiple authentication methods and determines which method should be used at runtime. +This sample creates a new instance of the `CosmosClient` class and authenticates using a `DefaultAzureCredential` instance. -The client authentication code for this project is in the `src/web/Program.cs` file. --For example, your app can authenticate using your Visual Studio sign-in credentials when developing locally, and then use a system-assigned managed identity once it has been deployed to Azure. No code changes are required for this transition between environments. ---Alternatively, your app can specify a `clientId` with the <xref:Azure.Identity.DefaultAzureCredentialOptions> class to use a user-assigned managed identity locally or in Azure. - ### Get a database -The code to access database resources is in the `GenerateQueryDataAsync` method of the `src/web/Pages/Index.razor` file. --Use the <xref:Microsoft.Azure.Cosmos.CosmosClient.GetDatabase%2A> method to return a reference to the specified database. +Use `client.GetDatabase` to retrieve the existing database named *`cosmicworks`*. ### Get a container -The code to access container resources is also in the `GenerateQueryDataAsync` method. --The <xref:Microsoft.Azure.Cosmos.Database.GetContainer%2A> returns a reference to the specified container. +Retrieve the existing *`products`* container using `database.GetContainer`. ### Create an item -The easiest way to create a new item in a container is to first build a C# class or record type with all of the members you want to serialize into JSON. In this example, the C# record has a unique identifier, a `category` field for the partition key, name, quantity, price, and clearance fields. +Build a C# record type with all of the members you want to serialize into JSON. In this example, the type has a unique identifier, and fields for category, name, quantity, price, and sale. :::code language="csharp" source="~/cosmos-db-nosql-dotnet-quickstart/src/web/Models/Product.cs" id="model"::: -In the `GenerateQueryDataAsync` method, create an item in the container by calling <xref:Microsoft.Azure.Cosmos.Container.UpsertItemAsync%2A>. +Create an item in the container using `container.UpsertItem`. This method "upserts" the item effectively replacing the item if it already exists. ### Read an item -In Azure Cosmos DB, you can perform a point read operation by using both the unique identifier (`id`) and partition key fields. In the SDK, call <xref:Microsoft.Azure.Cosmos.Container.ReadItemAsync%2A> passing in both values to return a deserialized instance of your C# type. -Still in the `GenerateQueryDataAsync` method, use `ReadItemAsync<Product>` to serialize the item using the `Product` type. +Perform a point read operation by using both the unique identifier (`id`) and partition key fields. Use `container.ReadItem` to efficiently retrieve the specific item. ### Query items -After you insert an item, you can run a query to get all items that match a specific filter. This example runs the SQL query: `SELECT * FROM products p WHERE p.category = "gear-surf-surfboards"`. This example uses the QueryDefinition type and a parameterized query expression for the partition key filter. Once the query is defined, call <xref:Microsoft.Azure.Cosmos.Container.GetItemQueryIterator%2A> to get a result iterator that manages the pages of results. In the example, the query logic is also in the `GenerateQueryDataAsync` method. ---Then, use a combination of `while` and `foreach` loops to retrieve pages of results and then iterate over the individual items. ---## Clean up resources ---When you no longer need the sample application or resources, remove the corresponding deployment and all resources. +Perform a query over multiple items in a container using `container.GetItemQueryIterator`. Find all items within a specified category using this parameterized query: -```azurecli-interactive -azd down +```nosql +SELECT * FROM products p WHERE p.category = @category ``` ---### [Try Azure Cosmos DB free](#tab/try-free) --1. Navigate to the **Try Azure Cosmos DB free** homepage again: <https://cosmos.azure.com/try/> -1. Sign-in using your Microsoft account. +Parse the paginated results of the query by looping through each page of results using `feed.ReadNextAsync`. Use `feed.HasMoreResults` to determine if there are any results left at the start of each loop. -1. Select **Delete your account**. -### [Azure subscription](#tab/azure-subscription) +## Clean up resources -When you no longer need the API for NoSQL account, you can delete the corresponding resource group. Use the `az group delete` command to delete the resource group. -```azurecli -az group delete --name <resource-group-name> -``` +## Related content --+- [JavaScript/Node.js Quickstart](quickstart-nodejs.md) +- [Java Quickstart](quickstart-java.md) +- [Python Quickstart](quickstart-python.md) +- [Go Quickstart](quickstart-go.md) ## Next step > [!div class="nextstepaction"]-> [Tutorial: Develop a .NET console application with Azure Cosmos DB for NoSQL](tutorial-dotnet-console-app.md) +> [Tutorial: Develop a .NET console application](tutorial-dotnet-console-app.md) |
cosmos-db | Quickstart Go | https://github.com/MicrosoftDocs/azure-docs/commits/main/articles/cosmos-db/nosql/quickstart-go.md | Title: 'Quickstart: Build a Go app using Azure Cosmos DB for NoSQL account' -description: Gives a Go code sample you can use to connect to and query the Azure Cosmos DB for NoSQL + Title: Quickstart - Go client library ++description: Deploy a Go web application that uses the client library to interact with Azure Cosmos DB for NoSQL data in this quickstart. ++ ms.devlang: golang-- Previously updated : 3/4/2021-+ Last updated : 01/08/2024+zone_pivot_groups: azure-cosmos-db-quickstart-env +# CustomerIntent: As a developer, I want to learn the basics of the Go library so that I can build applications with Azure Cosmos DB for NoSQL. -# Quickstart: Build a Go application using an Azure Cosmos DB for NoSQL account +# Quickstart: Azure Cosmos DB for NoSQL library for Go + [!INCLUDE[NoSQL](../includes/appliesto-nosql.md)] -> [!div class="op_single_selector"] -> -> * [.NET](quickstart-dotnet.md) -> * [Node.js](quickstart-nodejs.md) -> * [Java](quickstart-java.md) -> * [Spring Data](quickstart-java-spring-data.md) -> * [Python](quickstart-python.md) -> * [Spark v3](quickstart-spark.md) -> * [Go](quickstart-go.md) -> -> [!IMPORTANT] -> The Go SDK for Azure Cosmos DB is currently in beta. This beta is provided without a service-level agreement, and we don't recommend it for production workloads. Certain features might not be supported or might have constrained capabilities. -> -> For more information, see [Supplemental Terms of Use for Microsoft Azure Previews](https://azure.microsoft.com/support/legal/preview-supplemental-terms/). +Get started with the Azure Cosmos DB for NoSQL client library for Go to query data in your containers and perform common operations on individual items. Follow these steps to deploy a minimal solution to your environment using the Azure Developer CLI. +[API reference documentation](https://pkg.go.dev/github.com/Azure/azure-sdk-for-go/sdk/cosmos/azcosmos) | [Library source code](https://github.com/Azure/azure-sdk-for-go/tree/main/sdk/data/azcosmos#readme) | [Package (Go)](https://pkg.go.dev/github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos) | [Azure Developer CLI](/azure/developer/azure-developer-cli/overview) -In this quickstart, you'll build a sample Go application that uses the Azure SDK for Go to manage an Azure Cosmos DB for NoSQL account. Without a credit card or an Azure subscription, you can set up a free [Try Azure Cosmos DB account](https://aka.ms/trycosmosdb) +## Prerequisites -Azure Cosmos DB is a multi-model database service that lets you quickly create and query document, table, key-value, and graph databases with global distribution and horizontal scale capabilities. -To learn more about Azure Cosmos DB, go to [Azure Cosmos DB](../introduction.md). +## Setting up -## Prerequisites +Deploy this project's development container to your environment. Then, use the Azure Developer CLI (`azd`) to create an Azure Cosmos DB for NoSQL account and deploy a containerized sample application. The sample application uses the client library to manage, create, read, and query sample data. -- An Azure account with an active subscription.- - No Azure subscription? You can [try Azure Cosmos DB free](../try-free.md) with no credit card required. -- [Go 1.16 or higher](https://golang.org/dl/)-- [Azure CLI](/cli/azure/install-azure-cli) +[![Open in GitHub Codespaces](https://img.shields.io/static/v1?style=for-the-badge&label=GitHub+Codespaces&message=Open&color=brightgreen&logo=github)](https://codespaces.new/azure-samples/cosmos-db-nosql-go-quickstart?template=false&quickstart=1&azure-portal=true) -## Getting started -For this quickstart, you'll need to create an Azure resource group and an Azure Cosmos DB account. -Run the following commands to create an Azure resource group: +[![Open in Dev Container](https://img.shields.io/static/v1?style=for-the-badge&label=Dev+Containers&message=Open&color=blue&logo=visualstudiocode)](https://vscode.dev/redirect?url=vscode://ms-vscode-remote.remote-containers/cloneInVolume?url=https://github.com/azure-samples/cosmos-db-nosql-go-quickstart) -```azurecli -az group create --name myResourceGroup --location eastus -``` -Next create an Azure Cosmos DB account by running the following command: -``` -az cosmosdb create --name my-cosmosdb-account --resource-group myResourceGroup -``` +### Install the client library -### Install the package +The client library is available through Go, as the `azcosmos` package. -Use the `go get` command to install the [azcosmos](https://pkg.go.dev/github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos) package. +1. Open a terminal and navigate to the `/src` folder. -```bash -go get github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos -``` + ```bash + cd ./src + ``` ++1. If not already installed, install the `azcosmos` package using `go install`. ++ ```bash + go install github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos + ``` ++1. Also, install the `azidentity` package if not already installed. ++ ```bash + go install github.com/Azure/azure-sdk-for-go/sdk/azidentity + ``` ++1. Open and review the **src/go.mod** file to validate that the `github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos` and `github.com/Azure/azure-sdk-for-go/sdk/azidentity` entries both exist. -## Key concepts +## Object model -* A `Client` is a connection to an Azure Cosmos DB account. -* Azure Cosmos DB accounts can have multiple `databases`. A `DatabaseClient` allows you to create, read, and delete databases. -* Database within an Azure Cosmos DB Account can have multiple `containers`. A `ContainerClient` allows you to create, read, update, and delete containers, and to modify throughput provision. -* Information is stored as items inside containers. And the client allows you to create, read, update, and delete items in containers. +| Name | Description | +| | | +| [`CosmosClient`](https://pkg.go.dev/github.com/Azure/azure-sdk-for-go/sdk/cosmos/azcosmos#CosmosClient) | This class is the primary client class and is used to manage account-wide metadata or databases. | +| [`CosmosDatabase`](https://pkg.go.dev/github.com/Azure/azure-sdk-for-go/sdk/cosmos/azcosmos#CosmosDatabase) | This class represents a database within the account. | +| [`CosmosContainer`](https://pkg.go.dev/github.com/Azure/azure-sdk-for-go/sdk/cosmos/azcosmos#CosmosContainer) | This class is primarily used to perform read, update, and delete operations on either the container or the items stored within the container. | +| [`PartitionKey`](https://pkg.go.dev/github.com/Azure/azure-sdk-for-go/sdk/cosmos/azcosmos#PartitionKey) | This class represents a logical partition key. This class is required for many common operations and queries. | ## Code examples -**Authenticate the client** --```go -var endpoint = "<azure_cosmos_uri>" -var key = "<azure_cosmos_primary_key" --cred, err := azcosmos.NewKeyCredential(key) -if err != nil { - log.Fatal("Failed to create a credential: ", err) -} --// Create a CosmosDB client -client, err := azcosmos.NewClientWithKey(endpoint, cred, nil) -if err != nil { - log.Fatal("Failed to create Azure Cosmos DB client: ", err) -} --// Create database client -databaseClient, err := client.NewDatabase("<databaseName>") -if err != nil { - log.Fatal("Failed to create database client:", err) -} --// Create container client -containerClient, err := client.NewContainer("<databaseName>", "<containerName>") -if err != nil { - log.Fatal("Failed to create a container client:", err) -} -``` +- [Authenticate the client](#authenticate-the-client) +- [Get a database](#get-a-database) +- [Get a container](#get-a-container) +- [Create an item](#create-an-item) +- [Get an item](#read-an-item) +- [Query items](#query-items) -**Create an Azure Cosmos DB database** --```go -import ( - "context" - "log" - "github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos" -) --func createDatabase (client *azcosmos.Client, databaseName string) error { -// databaseName := "adventureworks" -- // sets the name of the database - databaseProperties := azcosmos.DatabaseProperties{ID: databaseName} -- // creating the database - ctx := context.TODO() - databaseResp, err := client.CreateDatabase(ctx, databaseProperties, nil) - if err != nil { - log.Fatal(err) - } - return nil -} -``` -**Create a container** --```go -import ( - "context" - "log" - "github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos" -) --func createContainer (client *azcosmos.Client, databaseName, containerName, partitionKey string) error { -// databaseName = "adventureworks" -// containerName = "customer" -// partitionKey = "/customerId" - - databaseClient, err := client.NewDatabase(databaseName) // returns a struct that represents a database - if err != nil { - log.Fatal("Failed to create a database client:", err) - } -- // Setting container properties - containerProperties := azcosmos.ContainerProperties{ - ID: containerName, - PartitionKeyDefinition: azcosmos.PartitionKeyDefinition{ - Paths: []string{partitionKey}, - }, - } -- // Setting container options - throughputProperties := azcosmos.NewManualThroughputProperties(400) //defaults to 400 if not set - options := &azcosmos.CreateContainerOptions{ - ThroughputProperties: &throughputProperties, - } -- ctx := context.TODO() - containerResponse, err := databaseClient.CreateContainer(ctx, containerProperties, options) - if err != nil { - log.Fatal(err) -- } - log.Printf("Container [%v] created. ActivityId %s\n", containerName, containerResponse.ActivityID) - - return nil -} -``` +### Authenticate the client -**Create an item** --```go -import ( - "context" - "log" - "github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos" -) --func createItem(client *azcosmos.Client, databaseName, containerName, partitionKey string, item any) error { -// databaseName = "adventureworks" -// containerName = "customer" -// partitionKey = "1" -/* - item = struct { - ID string `json:"id"` - CustomerId string `json:"customerId"` - Title string - FirstName string - LastName string - EmailAddress string - PhoneNumber string - CreationDate string - }{ - ID: "1", - CustomerId: "1", - Title: "Mr", - FirstName: "Luke", - LastName: "Hayes", - EmailAddress: "luke12@adventure-works.com", - PhoneNumber: "879-555-0197", - } -*/ - // Create container client - containerClient, err := client.NewContainer(databaseName, containerName) - if err != nil { - return fmt.Errorf("failed to create a container client: %s", err) - } -- // Specifies the value of the partiton key - pk := azcosmos.NewPartitionKeyString(partitionKey) -- b, err := json.Marshal(item) - if err != nil { - return err - } - // setting item options upon creating ie. consistency level - itemOptions := azcosmos.ItemOptions{ - ConsistencyLevel: azcosmos.ConsistencyLevelSession.ToPtr(), - } - ctx := context.TODO() - itemResponse, err := containerClient.CreateItem(ctx, pk, b, &itemOptions) -- if err != nil { - return err - } - log.Printf("Status %d. Item %v created. ActivityId %s. Consuming %v Request Units.\n", itemResponse.RawResponse.StatusCode, pk, itemResponse.ActivityID, itemResponse.RequestCharge) -- return nil -} -``` -**Read an item** --```go -import ( - "context" - "log" - "fmt" - "github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos" -) --func readItem(client *azcosmos.Client, databaseName, containerName, partitionKey, itemId string) error { -// databaseName = "adventureworks" -// containerName = "customer" -// partitionKey = "1" -// itemId = "1" -- // Create container client - containerClient, err := client.NewContainer(databaseName, containerName) - if err != nil { - return fmt.Errorf("Failed to create a container client: %s", err) - } -- // Specifies the value of the partiton key - pk := azcosmos.NewPartitionKeyString(partitionKey) -- // Read an item - ctx := context.TODO() - itemResponse, err := containerClient.ReadItem(ctx, pk, itemId, nil) - if err != nil { - return err - } -- itemResponseBody := struct { - ID string `json:"id"` - CustomerId string `json:"customerId"` - Title string - FirstName string - LastName string - EmailAddress string - PhoneNumber string - CreationDate string - }{} -- err = json.Unmarshal(itemResponse.Value, &itemResponseBody) - if err != nil { - return err - } -- b, err := json.MarshalIndent(itemResponseBody, "", " ") - if err != nil { - return err - } - fmt.Printf("Read item with customerId %s\n", itemResponseBody.CustomerId) - fmt.Printf("%s\n", b) -- log.Printf("Status %d. Item %v read. ActivityId %s. Consuming %v Request Units.\n", itemResponse.RawResponse.StatusCode, pk, itemResponse.ActivityID, itemResponse.RequestCharge) -- return nil -} -``` +This sample creates a new instance of `CosmosClient` using `azcosmos.NewClient` and authenticates using a `DefaultAzureCredential` instance. -**Delete an item** --```go -import ( - "context" - "log" - "github.com/Azure/azure-sdk-for-go/sdk/data/azcosmos" -) --func deleteItem(client *azcosmos.Client, databaseName, containerName, partitionKey, itemId string) error { -// databaseName = "adventureworks" -// containerName = "customer" -// partitionKey = "1" -// itemId = "1" -- // Create container client - containerClient, err := client.NewContainer(databaseName, containerName) - if err != nil { - return fmt.Errorf("Failed to create a container client: %s", err) - } - // Specifies the value of the partiton key - pk := azcosmos.NewPartitionKeyString(partitionKey) -- // Delete an item - ctx := context.TODO() - res, err := containerClient.DeleteItem(ctx, pk, itemId, nil) - if err != nil { - return err - } -- log.Printf("Status %d. Item %v deleted. ActivityId %s. Consuming %v Request Units.\n", res.RawResponse.StatusCode, pk, res.ActivityID, res.RequestCharge) -- return nil -} -``` -## Run the code +### Get a |