For customers who want to simplify complex and distributed environments across on-premises, edge and multi-cloud, Azure Arc enables deployment of Azure services anywhere and extends Azure management to any infrastructure.
-
Organize and govern across environments - Get databases, Kubernetes clusters, and servers sprawling across on-premises, edge and multi-cloud environments under control by centrally organizing and governing from a single place.
-
Manage Kubernetes Apps at scale - Deploy and manage Kubernetes applications across environments using DevOps techniques. Ensure that applications are deployed and configured from source control consistently.
-
Run data services anywhere - Get automated patching, upgrades, security and scale on-demand across on-premises, edge and multi-cloud environments for your data estate.
The following guides will walk you through the process of setting up demos that show how to get started with Azure Arc. They are designed with a "zero to hero" approach in mind and with as much automation as possible. The goal is for you to have a working Azure Arc demo environment spun up in no time so you can focus on showing the core values of the solution.
Disclaimer: The intention for this repo is to focus on the core Azure Arc capabilities, deployment scenarios, use-cases and ease of use. It does not focus on Azure best-practices or the other tech and OSS projects being leveraged in the guides and code.
Fabrikam Global Manufacturing runs workloads on different hardware, across on-premises datacenters, and multiple public clouds, with Microsoft Azure being the primary cloud. They also support IoT workloads deployed on the edge. Workloads include very diverse services and are based on either virtual machines, managed Platform-as-a-Service (PaaS) services, and container-based applications.
As mentioned, Fabrikam’s R&D teams are well-invested in containerized workloads for their modernized applications. As a result, they are using Kubernetes as their container orchestration platform. Kubernetes is deployed both as self-managed Kubernetes clusters in their on-premises environments and managed Kubernetes deployments in the cloud.
As part of their cloud-native practices with Azure being the main hyper-scale cloud, Fabrikam’s operations teams are standardized and taking advantage of Azure Resource Manager (ARM) capabilities such as (but not limited to) tagging, Azure Monitoring for VMs and containers, logging and telemetry, policy and government, Desired State Configuration (DSC), Update Management, Change Tracking, Inventory management, etc.
These practices and techniques are already well established for Azure-based workloads in use such as Azure VMs, Azure Kubernetes Service (AKS), Azure SQL, and many more. In order to take advantage of these well-established practices, Fabrikam is using Azure Arc to extend the ARM APIs to project and manage their workloads deployed outside of Azure. Once onboarded, Azure Arc projects resources as first-class citizens in Azure which can then take advantage of the ARM capabilities mentioned above. In addition, they are able to guarantee Kubernetes deployments and app consistency through GitOps-based configuration for their Kubernetes clusters in Azure, other clouds and on-premises.
With Azure Arc, Fabrikam is able to project resources and register them into Azure Resource Manager independently of where they run, so they have a single control plane and can extend cloud-native operations and governance beyond Azure.
The deployment scenarios below will guide you through onboarding various Windows and Linux server deployments to Azure with Azure Arc.
Note: For a list of supported operating systems and Azure regions, please visit the official Azure Arc docs.
The following examples can be used to connect existing Windows or Linux servers to Azure with Azure Arc. Use these if you already have existing servers that you want to project into Azure.
The following guides in this section will walk you through how to project an Azure VM as an Azure Arc enabled server. These guides, using Azure VM as the targeted Azure Arc server are designed for demo and testing purposes ONLY and are not supported.
In each guide, you find a detailed, technical explanation of the mechanism and why it is not expected to project an Azure VM as an Azure Arc enabled server.
-
Deploy a Windows Azure VM and connect it to Azure Arc using ARM Template
-
Deploy an Ubuntu Azure VM and connect it to Azure Arc using ARM Template
If you don't have any existing servers available, you can use Vagrant to host a new server locally and onboard it to Azure. This will allow you to simulate "on-premises" servers from your local machine.
-
Deploy a local Ubuntu VM and connect it to Azure Arc using Vagrant
-
Deploy a local Windows 10 VM and connect it to Azure Arc using Vagrant
Azure Arc can project servers into Azure from any public cloud. The following guides provide end-to-end deployment of new Linux servers in AWS EC2 and onboarding to Azure with Azure Arc using Terraform.
-
Deploy an AWS EC2, Ubuntu VM and connect it to Azure Arc using Terraform
-
Deploy an AWS Amazon Linux 2 VM and connect it to Azure Arc using Terraform
The following guides provide end-to-end deployment of new Windows or Linux servers in Google Cloud and onboarding to Azure with Azure Arc using Terraform.
-
Deploy a GCP Ubuntu VM and connect it to Azure Arc using Terraform
-
Deploy a GCP Windows Server VM and connect it to Azure Arc using Terraform
The following guides provide end-to-end deployment of new Windows or Linux servers in VMware and onboarding to Azure with Azure Arc using Terraform.
-
Deploy a VMware vSphere Ubuntu Server VM and connect it to Azure Arc using Terraform
-
Deploy a VMware vSphere Windows Server VM and connect it to Azure Arc using Terraform
Once you have server resources projected into Azure with Azure Arc, you can start to use native Azure tooling to manage the servers as native Azure resources. The following guides show examples of using Azure management tools such as resource tags, Azure Policy, Log Analytics, and more with Azure Arc enabled servers.
-
Tagging and querying server inventory across multiple clouds using Resource Graph Explorer
-
Deploying Custom Script Extension to Azure Arc Linux and Windows VMs using Extension Management
-
Integrate Azure Security Center with Azure Arc enabled Servers
The following guides are designed to provide scaled onboarding experience to Azure Arc of virtual machines deployed in various platforms and existing environments.
-
Scaled Onboarding VMware vSphere Windows Server VMs to Azure Arc
-
Scaled Onboarding AWS EC2 instances to Azure Arc using Ansible
The deployment scenarios below will guide you through onboarding Microsoft SQL Server, deployed on various platforms to Azure Arc.
The following guide in this section will walk you through how to project an Azure VM installed with SQL Server as an Azure Arc enabled server and Azure Arc enabled SQL. This guide, using Azure VM is designed for demo and testing purposes ONLY and is not supported.
In each guide, you find a detailed, technical explanation of the mechanism and why it is not expected to project an Azure VM as an Azure Arc enabled server.
The following guide provide end-to-end deployment of new Windows Server install with SQL Server in AWS and onboarding to Azure with Azure Arc using Terraform.
The following guide provide end-to-end deployment of new Windows Server install with SQL Server in GCP and onboarding to Azure with Azure Arc using Terraform.
The following guide provide end-to-end deployment of new Windows Server install with SQL Server in VMware vSphere and onboarding to Azure with Azure Arc using Terraform.
The below deployment options are focused on Azure Arc enabled Kubernetes. They are designed to quickly spin up a Kubernetes cluster that is ready to be projected in Azure Arc and ready for use with Azure native tooling.
Disclaimer: Azure Arc enabled Kubernetes is currently in Public Preview.
This example demonstrates how to connect an existing Kubernetes cluster to Arc. It assumes you already have a cluster ready to work with.
If you do not yet have a Kubernetes cluster, the following examples walk through creating an AKS cluster to simulate an "on-premises" cluster. Examples are provided for deploying with either Terraform or with an ARM template.
-
Deploy AKS cluster and connect it to Azure Arc using Azure ARM template
-
Deploy AKS cluster and connect it to Azure Arc using Terraform
This example uses Terraform to deploy an EKS cluster on AWS and connect it to Azure with Azure Arc.
This example uses Terraform to deploy a GKE cluster on Google Cloud and connect it to Azure with Azure Arc.
These examples deploy Rancher k3s on an Azure VM or VMware and onboards the cluster with Azure Arc.
-
Deploy Rancher k3s on an Azure VM and connect it to Azure Arc using Azure ARM template
-
Deploy Rancher k3s on an Azure VM and connect it to Azure Arc using Terraform
-
Deploy Rancher k3s on a VMware vSphere VM and connect it to Azure Arc using Terraform
Azure Arc can also support Azure Red Hat OpenShift (ARO). This example uses Terraform to deploy a new ARO cluster and onboards it to Azure with Azure Arc.
This example walks you through how to create a Kubernetes cluster on your local machine using kind (kubernetes in docker), and onboard it as an Azure Arc enabled Kubernetes cluster
This example walks you through how to create a Kubernetes cluster on your local machine using MicroK8s, and onboard it as an Azure Arc enabled Kubernetes cluster
Once you have Kubernetes clusters projected into Azure with Azure Arc, you can start to use native Azure tooling to manage the clusters as native Azure resources. The following guides show examples of using Azure management tools such as Azure Monitor, GitOps configurations, and Azure Policy.
-
Deploy GitOps configurations and perform basic GitOps flow on AKS as an Azure Arc Connected Cluster
-
Integrate Azure Monitor for Containers with AKS as an Azure Arc Connected Cluster
-
Deploy GitOps configurations and perform basic GitOps flow on GKE as an Azure Arc Connected Cluster
-
Integrate Azure Monitor for Containers with GKE as an Azure Arc Connected Cluster
The below deployment options are focused on Azure Arc enabled Data Services. They are designed to quickly spin up a new Kubernetes cluster and deploy Azure Arc enabled data services that are ready to be projected in Azure Arc and ready for use with Azure native tooling.
[!NOTE] Already have a Kubernetes cluster? Deploy Azure Arc enabled data services to an existing Kubernetes cluster
Disclaimer: Azure Arc enabled Data Services is currently in Public Preview.
If you do not yet have a Kubernetes cluster, the following examples walk through creating an AKS cluster and deploy Azure Arc Data Services on top of it.
-
Azure Arc Data Controller Vanilla Deployment on AKS using Azure ARM template
-
Azure SQL Managed Instance Deployment on AKS using Azure ARM template
-
Azure PostgreSQL Hyperscale Deployment on AKS using Azure ARM template
If you do not yet have a Kubernetes cluster, the following examples walk through creating an EKS cluster and deploy Azure Arc Data Services on top of it.
If you do not yet have a Kubernetes cluster, the following examples walk through creating a GKE cluster and deploy Azure Arc Data Services on top of it.
If you do not yet have a Kubernetes cluster, the following examples walk through creating an single-node Kubernetes cluster to simulate a full scale Kubernetes cluster and deploy Azure Arc Data Services on top of it.
Up-to-date roadmap for the Azure Arc scenarios to be covered can be found under this repository GitHub Project.
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
Before contributing code, please see the CONTRIBUTING guide.
Issues, PRs and Feature Request have their own templates. Please fill out the whole template.
Microsoft and any contributors grant you a license to the Microsoft documentation and other content in this repository under the Creative Commons Attribution 4.0 International Public License, see the LICENSE file, and grant you a license to any code in the repository under the MIT License, see the LICENSE-CODE file.
Microsoft, Windows, Microsoft Azure and/or other Microsoft products and services referenced in the documentation may be either trademarks or registered trademarks of Microsoft in the United States and/or other countries. The licenses for this project do not grant you rights to use any Microsoft names, logos, or trademarks. Microsoft's general trademark guidelines can be found at http://go.microsoft.com/fwlink/?LinkID=254653.
Privacy information can be found at https://privacy.microsoft.com/
Microsoft and any contributors reserve all other rights, whether under their respective copyrights, patents, or trademarks, whether by implication, estoppel or otherwise.