Introduction
In this blog I am looking at Azure Arc-enabled data services and one of the main reasons to use them – SQL Managed Instances (MI). I am going to highlight why you might want to use SQL MI’s and am going to provide you with a guide of how to deploy them onto your Azure Stack HCI clusters.
Please note that there are a lot of pieces that need to be put together to get this working, and not everything can be covered in a single post. There are some excellent documents provided by Microsoft and I have endeavoured to collate the pertinent parts in this blog to give you a good starting point to deploy onto an Azure Stack HCI Cluster. The examples in this blog will be for Portal deployments, and command line tools are also available.
What are SQL Manged Instances?
A SQL Managed Instance (MI) enabled by Azure Arc is an Azure SQL data service that can be created on the infrastructure of your choice. In this blog we are focusing on Azure Stack HCI, although Azure Arc makes it possible to run Azure data services on-premises, at the edge, and in public clouds using Kubernetes and the infrastructure of your choice.
Why would I want to use SQL Managed Instances?
There are many benefits to running SQL MI’s on Azure Stack HCI in your own DC’s or remote locations. SQL Managed Instances have near 100% compatibility with the latest SQL Server database engine, and enables existing SQL Server customers to lift and shift their applications to Azure Arc data services with minimal application and database changes while maintaining data sovereignty. At the same time, SQL Managed Instances include built-in management capabilities that drastically reduce management overhead.
The main benefits come part of Azure Arc data services, and are summarised as per below:
data:image/s3,"s3://crabby-images/4f4ab/4f4ab234593e674209887342968941814f4d4f91" alt=""
Always current | Receive updates on a frequent basis including servicing patches and new features similar to the experience in Azure. Updates from the Microsoft Container Registry are provided to you and deployment cadences are set by you in accordance with your policies. Stay up to date while ensuring you maintain control. Because Azure Arc-enabled data services are a subscription service, you will no longer face end-of-support situations for your databases. |
Elastic scale | Cloud-like elasticity on-premises enables you to scale databases up or down dynamically in much the same way as they do in Azure, based on the available capacity of your infrastructure. |
Self-service provisioning | Thanks to Kubernetes-based orchestration, you can deploy a database in seconds using either GUI or CLI tools. |
Unified management | Gain a unified view of all your data assets deployed with Azure Arc using familiar tools such as the Azure portal, Azure Data Studio, and the Azure CLI. View and manage a variety of databases across your environment and Azure, and also get logs and telemetry from Kubernetes APIs to analyze the underlying infrastructure capacity and health. Leverage Azure Monitor for comprehensive operational insights across your entire estate (in additional to localised log analytics and performance monitoring). |
Disconnected scenario support | Run services locally in your infrastructure with or without a direct connection to Azure. Indirect scenarios require that you already have your own local Kubernetes cluster |
Differences in Management Capabilities
There are some differences running a local SQL MI service on Azure Stack HCI when compared to running it as a PaaS service in Azure, which are detailed below:
data:image/s3,"s3://crabby-images/6e593/6e593b152117898724ec630a72bbff70c75f4461" alt=""
Elastic / “Limitless” scalability | Limited by the infrastructure a the customers site |
Automatic HA/DR | The underlying Hardware/K8s availability is the responsibility of the customer |
Compliance certificates | Responsibility of the customer |
Data sovereignty | Azure regions not available in all countries, customer can deploy to their own locations / DCs |
Customer control | Predefined hardware options in Azure |
Fully managed by Microsoft | Responsibility of the customer to support the solution (management features are provided) |
Guaranteed availability SLA | Responsibility of the customer, not offered by Microsoft |
Connectivity Modes
There are two main options for connectivity from your Azure Arc-enabled data services environment to Azure, and your choice will be based on business policy and government regulation requirements, or the availability of network connectivity to Azure. The connectivity modes are:
- Directly connected
- Indirectly connected
The connectivity mode provides you the flexibility to choose how much data is sent to Azure and how users interact with the Arc Data Controller. Depending on the connectivity mode that is chosen, some functionality of Azure Arc-enabled data services might or might not be available. To leverage Azure APIs then you will need to use connected mode and Microsoft Entra ID and Azure Role-Based Access Control can be used in the directly connected mode only because there’s a dependency on a continuous and direct connection to Azure to provide this functionality.
For Azure Stack HCI, Azure data services and SQL MI’s are deployed to Arc-enabled Aks clusters and so you will using Directly connected mode.
data:image/s3,"s3://crabby-images/023f7/023f7cdd6ed68a34d5fe729d48ae0e5adff5bde8" alt=""
Deployment onto Azure Stack HCI
Prerequisites
Azure Arc-enabled SQL Managed Instance (MI) requires a working Kubernetes cluster has already been deployed and added to Azure Arc and has proper internet connectivity for Azure data services. Below is a list of resources required for SQL MI:
- AKS Cluster deployed to the Azure Stack HCI cluster
- Logical Network
- Load Balancer
- Data Controller resource
- Custom Location
- K8s Configuration template
- AD Connector resource
- Active Directory Organizational Unit
- Active Directory Service Account
- Primary DNS Name
- Secondary DNS Name
- Manually created DNS A Records for the DNS Names
- SQL Managed Instance
- Log Analytics Workspace for Logs and Metrics
Deploy an Aks Cluster
Before you can configure Arc Data Services and deploy a SQL MI, you need to deploy a dedicated Kubernetes cluster for the SQL services to run on. Deploying an Aks clustering is beyond the scope of this blog as we are concentrating on SQL MI, but you can easily deploy an Kubernetes cluster via Azure Arc on Azure Stack HCI:
data:image/s3,"s3://crabby-images/9df1a/9df1ae08865419b90c4eeda85335af22edc6cff3" alt=""
After the Aks cluster is deployed, create a Load Balancer with a minimum of 4 x IP Addresses:
data:image/s3,"s3://crabby-images/e0cb5/e0cb5649a5c61135cb32dacd42e6697e1e1afdee" alt=""
Recommended Base Configuration
The below is a recommended base configuration for the Aks cluster, on experience. Azure arc data and SQL MI services where found to require a lot of resources and the most consistent and reliable experiences was with deploying the Aks VMs using the highest spec. Also, for resiliency, deploy at least 3 x Control Plane and 3 x Node Pools VMs:
- Install AKS clusters with 3 x Control Plane and 3 x Node Pool VMs
- Install AKS clusters with largest vCPU and memory profile (8 x vCPU & 32GB or memory)
- When configuring the Load Balancer for the AKS cluster, ensure it has at least 4 x IP addresses in the range (will require more as you expand out)
- Install Arc Data Services with a Load balancer
- Install SQL MI with a Load Balancer
- Create the AD Connector before creating the SQL MI
Azure Arc Data Controller
The key to being able to deploy Azure arc Data services is the Data Controller. Once the Data Controller is deployed onto the Aks cluster, then the data services, e.g. SQL MI, can be deployed.
Currently, only one Azure Arc data controller per Kubernetes cluster is supported. However, you can create multiple Arc data services, such as Arc-enabled SQL managed instances and Arc-enabled PostgreSQL servers, that are managed by the same Azure Arc data controller.
When you deploy Azure Arc data services, the Azure Arc Data Controller is one of the most critical components that is deployed. The functions of the data controller include:
- Provision, de-provision and update resources
- Orchestrate most of the activities for SQL Managed Instance enabled by Azure Arc such as upgrades, scale out etc.
- Capture the billing and usage information of each Arc SQL managed instance.
In order to perform above functions, the Data controller needs to store an inventory of all the current Arc SQL managed instances, billing, usage and the current state of all these SQL managed instances. All this data is stored in a database called controller
within the SQL Server instance that is deployed into the controldb-0
pod.
Deployment of the Data Controller
1. Search for ‘Azure Arc Data Controllers’ in the Portal, select the Service and then click ‘Create’
![]() | ![]() |
2. Select the connectivity mode (in our case, since we will be using and Aks cluster deployed to Azure Stack HCI, we will be using ‘direct connectivity mode’)
data:image/s3,"s3://crabby-images/972b0/972b0345bce223c48538bc2c28155ad3d5f51b73" alt=""
3. Under the details tab, enter the Subscription, Resource Group and Name for the data controller.
data:image/s3,"s3://crabby-images/e57aa/e57aae103b94f0b25c4f4660054a2fa761e36f01" alt=""
4. Also under the details tab, click ‘Create new custom location’ to create a custom location for the service. Enter a unique name and then select the target Aks cluster from the Cluster drop-down box. This custom location will become the target for which you depoy your data services to, e.g. SQL MI, and also become the k8s namespace under which the container services run.
data:image/s3,"s3://crabby-images/c7211/c7211e586e096e1f04398aa504b5670ab507d559" alt=""
5. Still under the details tab, select the k8s configuration template, which defines the storage class. There are predefined templates and you can also configure a customer template. In this example we are using the predefined template designed for Azure Stack HCI.
6. Select ‘Load Balancer’ as the service type to utlise the Aks load balancer and expose services via the LB’s
7. Enter a username and password for the logs and metric dashboard.
data:image/s3,"s3://crabby-images/60b76/60b76e168a353d1f9ee457066725217d38c2299e" alt=""
8. Configure the Azure Monitor settings and point to your Log Analytics Workspace
data:image/s3,"s3://crabby-images/9d5df/9d5dfac96253b68aee99f1ff5df5b52b5ea3d1a6" alt=""
Note: the Log Analytics primary key can be found under the Agents section in the LAW
data:image/s3,"s3://crabby-images/d3950/d3950db3f0b01ced6cd062a7b2fcfce9aac07512" alt=""
9. Confirm the details summary and click ‘Create’
data:image/s3,"s3://crabby-images/3b90a/3b90a076147e10adfb80a13e3b6387e70d535887" alt=""
When deployment is complete, the Data Controller will be listed and status should be ‘In compliance’
data:image/s3,"s3://crabby-images/f5d71/f5d715a536dac2b4c1acb92d35af50e317865950" alt=""
AD Connector
SQL MI currently supports two authentication methods, SQL Authentication and Active Directory Authentication. When you deploy an instance with the intention to enable Active Directory authentication, the deployment needs to reference an Active Directory connector instance to use. Referencing the Active Directory connector in managed instance specification automatically sets up the needed environment in instance container to authenticate with Active Directory.
In order to enable Active Directory authentication to work, the instance must be deployed in an environment that allows it to communicate with the Active Directory domain.
For SQL MI with AD authentication, Azure Arc-enabled data services introduces a new Kubernetes-native Custom Resource Definition (CRD) called Active Directory Connector
. It provides instances running on the same data controller the ability to perform Active Directory authentication.
To enable Active Directory authentication for SQL Server on Linux and Linux containers, use a keytab file. The keytab file is a cryptographic file containing service principal names (SPNs), account names and hostnames. SQL Server uses the keytab file for authenticating itself to the Active Directory (AD) domain and authenticating its clients using Active Directory (AD).
There are two Active Directory integration modes that use keytab files:
- Customer-managed keytab (CMK)
- Service-managed keytab (SMK)
Typically, business will use the Service-managed integration mode as it more automated in it’s management and creation. In this mode, a pre-created OU is required and a domain service account with permissions on the OU to create the required AD objects.
Prerequisites
1. Add an Organizational unit:
data:image/s3,"s3://crabby-images/e1958/e1958a457b54ebd048eb3d6b855f6965964a24b4" alt=""
2. Create a domain service account with required permissions on the OU (system managed keytab):
Permissions:
- Read all properties
- Write all properties
- Create User objects
- Delete User objects
- Reset password (descendant user objects)
data:image/s3,"s3://crabby-images/337a4/337a42cdcc416bbf9bb61ddd355ee7a85bf9eb0e" alt=""
data:image/s3,"s3://crabby-images/5c971/5c971b8b06004efd893a57a51454fa7d21de87eb" alt=""
Deploying an AD Connector
1. Go to your Data Controller resource and click ‘Add Connector’ under the ‘Active Directory section
data:image/s3,"s3://crabby-images/89e6a/89e6a527c835581ed328ac720cd26952dd3752bc" alt=""
2. Enter a name and select ‘Automatic’ and fill out the details including the OU’s distinguished name, name server IP addresses (i.e. your DNS servers), domain details and service account details you created in the previous steps.
data:image/s3,"s3://crabby-images/d7719/d7719b90836958bde6ac70f08d2462e650e5ee9e" alt=""
2. Click ‘Add connector’ and wait for the deployment to complete
data:image/s3,"s3://crabby-images/5c2c2/5c2c2e3c9c255e5523bf9ac159606dfb795dcdb8" alt=""
SQL Managed Instance (MI)
Now we have an Aks Cluster, Arc Data Controller and AD Connector we are ready to deploy the SQL Managed Instance itself. The following steps will guide you on the deployment.
Deploy SQL MI
1. Search for ‘SQL managed instances – Azure Arc’ and click the ‘Create’ button
![]() | ![]() |
2. Select the subscription, resource group, enter an instance name, select the custom location and select the service type of ‘Load Balancer’. The custom location should be what you created when deploying the Data Controller a the previous step.
data:image/s3,"s3://crabby-images/6d24c/6d24c6dcbdf6f93258f5f87d9bbe882686169ed9" alt=""
3. Select the Compute + Storage configuration options. It’s in these options that you select the service tier, license type, and high availability, compute and storage options. These options will determine the cost of the solution that will not be covered in this blog. For this example, I have selected the business critical service tier, which allows up to 3 replicas and I also set the readable and synchronized secondaries to 2. I left the instance compute and storage to the defaults. Finally click on Apply.
Note: If deploying this in a lab, dev or test environment tick ‘For development use only’ to not incur any costs.
data:image/s3,"s3://crabby-images/c61db/c61dbb80342a2bd281af2044a0472ca0f0c768ac" alt=""
data:image/s3,"s3://crabby-images/ecbda/ecbda308612086a4be8dba7fa2b4e39eb68951ad" alt=""
4. Enter the directory services account username and password. This is the account setup in step 2 of the prerequisites in the previous section.
data:image/s3,"s3://crabby-images/7baa5/7baa501cf631545fdd3b4084e23bb65e85a804e6" alt=""
5. Configure the Active Directory settings by selecting the AD Connector name that was deployed earlier, adding an AD account name and Primary and Secondary DNS names. The Ad account will be created automatically and we’ll need to manually add DNS records for the DNS names after the deployment completes. Finally click ‘Review + create’.
data:image/s3,"s3://crabby-images/c1f73/c1f73fff7c57a77a1764ad36df869ea9dbe40db8" alt=""
6. Review the summary and click on ‘Create’ to begin the deployment.
data:image/s3,"s3://crabby-images/83a16/83a16776d3e602f4b7312779c74b1f303d3a895d" alt=""
Monitoring the deployment
Whilst the deployment is in progress the Status will show are “Creating”.
data:image/s3,"s3://crabby-images/54d01/54d016192eb94103069259bac4e49d8824a8aae4" alt=""
Once deployment is completed, the status will show as “Ready”.
data:image/s3,"s3://crabby-images/23653/23653b1257759c9c858bfe182c865fb98c262667" alt=""
Configuring DNS Names
In the above example, we created 2 x DNS names that are used as external endpoints to access the SQL instance. For these endpoints to work, we need to manually add DNS A records.
The IP addresses used for the DNS A records are in fact the IP addresses that get assigned to the Load Balancer services in the Aks cluster. To identify those IP addresses, you can look them up in the Aks cluster details in the Portal, or via kubectl commands on the command line.
Retrieving IP Addresses
To see the load balancer IP addresses in the Azure portal, navigate to your Aks cluster under the HCI cluster and under ‘Service and ingresses’ select the namespace under the filter drop-down. The namespace is the custom location name created when deploying the Data Controller in a previous step.
data:image/s3,"s3://crabby-images/8f545/8f545317ec42156d21b721a0fc521e2e82f5ff74" alt=""
data:image/s3,"s3://crabby-images/3a4c3/3a4c3f273e7ee96ee801f30d5bf40c447ba04a0f" alt=""
Add DNS A records for the primary and secondary DNS names as created when deploying the SQL MI in the previous step.
data:image/s3,"s3://crabby-images/73c2b/73c2b4c8ea9fdb97eec90b3c6a11fc0e648c7bda" alt=""
Connecting to the SQL MI
In this example I am using Azure Data Studio to connect to the SQL MI deployed previously. Azure Data Studio is installed onto a local management server in the environment that has network access to the external endpoints.
First open Azure Data Studio and then select ‘New Connection’ and fill out the connection details. The server details is the primary external endpoint that you can see in the SQL MI. For the first time to login, you will need to use a SQL Login, and the credentials are that of the domain service account created in a previous step.
data:image/s3,"s3://crabby-images/6f62d/6f62d8cde1a8b5bf24fc28fff08f99865f66f1d7" alt=""
data:image/s3,"s3://crabby-images/7e748/7e748466bd1d5e51da07b0f0bf5c54b58476331c" alt=""
data:image/s3,"s3://crabby-images/1b89d/1b89d9fc417d6af62e895fe629e74fe58ba75841" alt=""
data:image/s3,"s3://crabby-images/c17d2/c17d2c300948e4ada8acb5b7bfc9e1347459d6c4" alt=""
After you have logged in with the SQL login, you can add a AD groups or users for Windows Authentication.
data:image/s3,"s3://crabby-images/b8f7b/b8f7beee6869951958c19abcf52db9b74d274c69" alt=""
Note: if adding a group then you will need to log out and back into the server you are running Azure Data Studio from to update you account’s group context.
data:image/s3,"s3://crabby-images/ec5a5/ec5a5d7eaf498dbab581d47e0a1cef403c9a0d82" alt=""
Open a new connection and this time select ‘Windows Authentication’
data:image/s3,"s3://crabby-images/21d01/21d01069dde040ea4068f1db75c39e923735f0ed" alt=""
data:image/s3,"s3://crabby-images/fa938/fa93816a9c168f652d6b89e27c402bcfa1809765" alt=""
Conclusion
SQL MI’s are a wonderful technology leveraging the power of Kubernetes and I hoped you found this blog useful in helping you start your SQL MI journey. There is a lot more to be covered such as costs, sizing, performance, DR and I will hopefully cover these in future blogs.
As ever, please refer to the Microsoft documentation for further information and below are links to some of the articles I referenced in this blog:
https://learn.microsoft.com/en-us/azure/azure-arc/data
https://learn.microsoft.com/en-us/azure/azure-arc/data/managed-instance-overview