Azure Point to Site VPN

Free AWS Course for AWS Certified Cloud Practitioner (CLF-C01) Start Now!!

Expert-led Online Courses: Elevate Your Skills, Get ready for Future - Enroll Now!

In this article, we will gain knowledge about Point to Site VPN in Azure. But we will mostly focus on the practical demonstration. So, let us begin.

What is Point-to-Site Connectivity in Azure?

The most common method for connecting an on-premises network to an Azure VNet is through a Site-to-Site VPN. This VPN connection is established at the level of your edge firewall or router.

What if you connect from a distant location, such as your home? To do so, we can use the point-to-site method. The authentication between the endpoint and the Azure virtual network will be done using certificates in this method.

Azure Point to Site Connectivity Protocols

1. The OpenVPN® Protocol is a VPN protocol that is based on SSL/TLS. Because most firewalls open TCP port 443 outbound, which TLS uses, a TLS VPN solution can pass through them. Android, iOS (versions 11.0 and up), Windows, Linux, and Mac devices can all connect to OpenVPN (macOS versions 10.13 and above).

2. Secure Socket Tunneling Protocol (SSTP) is a TLS-based VPN protocol that is proprietary. Because most firewalls open TCP port 443 outbound, which TLS uses, a TLS VPN solution can pass through them. Only Windows devices are compatible with SSTP. All versions of Windows with SSTP and TLS 1.2 support are supported by Azure (Windows 8.1 and later).

3. IKEv2 VPN is an IPsec VPN solution based on standards. From a Mac device, you can connect to an IKEv2 VPN (macOS versions 10.11 and above).

How to create VNet in Azure?

Follow below steps to create VNet in Azure:

1: Firstly, you must sign into the Azure portal and then search for Virtual Network.

searching virtual network

Technology is evolving rapidly!
Stay updated with DataFlair on WhatsApp!!

2: Secondly, choose Virtual Network from Azure MarketPlace and then click on the create button.

choosing virtual network

virtual network

3: The Create virtual network page will appear after you select Create. Now, configure the Project details and Instance details VNet settings on the Basics tab.

basic information

4: In the IP provide the IPv4 address range and subnet.

networking information

5: In the security tab leave it as default.

security details

6: Provide appropriate tags

providing tags

7: Once last review all the settings and then hit on the create button.

validation checks

virtual network deployed

Creating Azure VPN Gateway

A VPN gateway is a type of virtual network gateway that sends encrypted traffic over the public Internet between an Azure virtual network and an on-premises location. There can only be one VPN gateway in every virtual network.

A subnet known as the gateway subnet is used by the virtual network gateway. The virtual network IP address range you specify when configuring your virtual network includes the gateway subnet. It contains the IP addresses for the resources and services of the virtual network gateway.

Follow the below steps to create VPN Gateway in Azure:

1: Firstly, search for Virtual Networks Gateway in the search box and then choose it from Azure MarketPlace. And, then hit on the create button.

searching virtual network gateway

2: In the basics section one must fill all the values.

project details and instance details

networking information

public ip address

3: In the tags provide appropriate tags that you can remember

providing tags

4: Review all the details and once the validation is passed click on the create button.

validation checking

deployment successfull

Note: Users should make a note that the deployment of the virtual network gateway might take up to 45 minutes of duration to complete.

Generating Certificates in Azure

Clients connecting to a VNet via a Point-to-Site VPN connection are authenticated using certificates in Azure.

You upload the public key information to Azure after you obtain a root certificate. Azure then considers the root certificate to be ‘trusted,’ allowing P2S to connect to the virtual network.

Client certificates will also be generated from the trusted root certificate and installed on each client computer.

When a client initiates a connection to the VNet, the client certificate is used to authenticate the client.

Generate a self-signed certificate or use a root certificate generated with an enterprise solution (recommended). Export the public certificate data (not the private key) as a Base64 encoded X.509.cer file after creating the root certificate. Then, on the Azure server, upload the public certificate data.

Run the following script in PowerShell as an administrator.

$cert = New-SelfSignedCertificate -Type Custom -KeySpec Signature `
-Subject “CN=SLP2SRootCert” -KeyExportPolicy Exportable `
-HashAlgorithm sha256 -KeyLength 2048 `
-CertStoreLocation “Cert:\CurrentUser\My” -KeyUsageProperty Sign -KeyUsage CertSign

generating certificate for client

It will create a root cert and install it under the current user cert store.

Generate Client Certificates from Root Certificate in Azure

Now, in the Powershell run the following command:

Get-ChildItem -Path “Cert:\CurrentUser\My”

The following should provide a thumbprint:

providing thumbprint

Now, run the following command. But, make sure the thumbprint should match your Certificate.

$cert = Get-ChildItem -Path “Cert:\CurrentUser\My\ 0FD6775DA36A288CC91EAC1702167112765B8F05

Lastly, enter the following command to generate client certificate

New-SelfSignedCertificate -Type Custom -KeySpec Signature `
-Subject “CN=SLP2SClientCert” -KeyExportPolicy Exportable -NotAfter (Get-Date).AddYears(1) `
-HashAlgorithm sha256 -KeyLength 2048 `
-CertStoreLocation “Cert:\CurrentUser\My” `
-Signer $cert -TextExtension @(“2.5.29.37={text}1.3.6.1.5.5.7.3.2”)

generating client certificate

We now have certificates in place, but we need to export the root certificate so that it can be uploaded to Azure.

To begin, export the public key for the root certificate (.cer)

To open the Run dialogue box, press Windows Key + “R” and type “certmgr.msc.” Your newly created certificate should appear in “Current UserPersonalCertificates” when the management console opens. Go to All Tasks > Export by right-clicking on your newly created certificate.

exporting certificate

Now click on the Next option in the wizard.

export wizard

Choose “No, do not export the private key” and then click on the Next button.

exporting private key

On the Export File Format page, choose Base-64 encoded X.509 (.CER)., and then click on the Next button.

choosing export file format

For File to Export, Browse and select a location to where you want to export the certificate then provide a file name. And, click Next.

specifying the location

Finally, click on the finish button and you will see the certificate on the saved location.

generated certificate

Configuring Point to Site Connection in Azure

The point-to-site connection will be configured next in this configuration. We’ll also define the pool of client IP addresses here. It’s for VPN clients.

1. Select the newly created VPN gateway connection by clicking on it.

2. Then click Point-to-Site Configuration in a new window.

3. Select Configure Now.

4. Type the VPN address pool’s IP address range in a new window. 20.20.20.0/24 will be used. Use both SSTP and IKEv2 for tunnelling. By default, IKEv2 is used to connect Linux and other mobile clients. In Windows, IKEv2 is used first, followed by SSTP. Use Azure Certificates for authentication.

5. There is a place to define a root certificate in the same window. Type the cert name in the root certificate name field, and paste the root certificate data in the public certificate data field ( you can open cert in notepad to get data).

6. Then, to finish the process, click Save.

Note: Do not copy the text —–BEGIN CERTIFICATE—– and —–END CERTIFICATE—– when pasting certificate data.

point to site configuration

Testing VPN Connection

From the machine, go to the VPN gateway configuration page in the Azure portal and follow below steps:

1: Select Point-to-Site Configuration from the drop-down menu.

2: Then, select Download VPN Client from the drop-down menu.

point to site configuring details

 

3: After downloading, extract or unzip the file and then double click on the VPN client setup.

downloading vpn client

4: Just allow the installation and after that, you will see a new connection under the windows 10 VPN page.

installing vpn client

5: Now, click on connect option in VPN.

connecting client vpn

6: Now, a new window will appear on the screen and click on the Connect option.

checking connection status and connecting

7: In the last step open the command prompt and then Run ipconfig to verify IP allocation from the VPN address pool.

verifying ip address

Conclusion

Thus, in today’s article, we covered all the information about Point-to-Site Connectivity along with the demonstration. We believe you liked this article and will be in our further Azure journey.

Did you like this article? If Yes, please give DataFlair 5 Stars on Google

courses

DataFlair Team

DataFlair Team creates expert-level guides on programming, Java, Python, C++, DSA, AI, ML, data Science, Android, Flutter, MERN, Web Development, and technology. Our goal is to empower learners with easy-to-understand content. Explore our resources for career growth and practical learning.

Leave a Reply

Your email address will not be published. Required fields are marked *