The title says it all... Since the beginning of my cloud journey, having the possibility to connect to SQL PaaS with a private IP is a highly wanted feature. Since a few days, this has been made possible by introducing a new service, called Private Link Center. Which is in preview while writing this blog post.
data:image/s3,"s3://crabby-images/29a19/29a193f706e54a7f245ce1b5a02b964738b99307" alt=""
When opening the service for the first time, we see some explanation regarding the actual service.
data:image/s3,"s3://crabby-images/24503/24503d980eb38c77f2ed86dd69ed4b5d385d4ff0" alt=""
At the bottom of this page, we can choose out of 3 different options.
data:image/s3,"s3://crabby-images/7306c/7306c64fd8dc9df6a0032880666df6477f8beb7b" alt=""
Our goal here is to connect to a SQL database using private communication only. So we will first need to create a private connection/endpoint to our SQL server (PaaS).
data:image/s3,"s3://crabby-images/575f0/575f097a540a0be7ddaddd9d6c3e8ffaa6b8a561" alt=""
On the second page, we actually need to already choose the type of resource and the resource itself. I created a demo SQL server as preparation, so we will pick that one.
data:image/s3,"s3://crabby-images/a0850/a0850d408bae8aba510edd2ff86d519b4af027dd" alt=""
The last step is choosing the right virtual network and subnet. As you will notice in the screenshot, I already prepared a subnet called 'privateendpoints'.
Regarding DNS you have 2 options:
- Create an Azure Private DNS Zone (privatelink.database.windows.net)
- Use your own IaaS hosted DNS servers
In this example we will use the Azure Private DNS Zone, this is the easiest way to demo the functionality. In a corporate environment, I would rather advise using your own IaaS hosted DNS servers for added control. Of course, everything depends on your requirements.
data:image/s3,"s3://crabby-images/dde99/dde99351da2aa3be2859bc0cd640bc1f09aaf202" alt=""
data:image/s3,"s3://crabby-images/9e153/9e153afae7837cf0733601b7de3342ded56c29dc" alt=""
When our deployment is finished up, we see an Azure DNS zone running privatelink.database.windows.net configured with one A record regarding our SQL Server.
data:image/s3,"s3://crabby-images/2ece6/2ece6cc414065d9413df80aa906daf2be7f742f3" alt=""
When browsing our SQL Server, I noticed that a new section under 'Security' appeared called 'Private Endpoint Connections'.
A connection was created while deploying the service:
data:image/s3,"s3://crabby-images/78d32/78d3279bb3326bd5810e01ade0fdcb7fb7e9ea70" alt=""
When actually testing the service from my demo VM:
- We are able to resolve the DNS A record to a private IP ✓
- We are able to open a connection to the private IP on port 1433 ✓
data:image/s3,"s3://crabby-images/e55d2/e55d2e6329b88bab583ec9b761e88b5af4a24039" alt=""
This feature will be much appreciated by our fellow security and firewall colleagues! Way to go Microsoft, hooray!
Comments