Public IP addresses
Public IP addresses allow Internet resources to communicate inbound to Azure resources. Public IP addresses enable Azure resources to communicate to Internet and public-facing Azure services. You dedicate the address to the resource until you unassign it. A resource without an assigned public IP can still communicate outbound. Azure automatically assigns an available dynamic IP address for outbound communication. This address isn't dedicated to the resource and can change over time. For more information about outbound connections in Azure, see Understand outbound connections.
In Azure Resource Manager, a public IP address is a resource that has its own properties.
The following resources can be associated with a public IP address:
- Virtual machine network interfaces
- Virtual Machine Scale Sets
- Azure Load Balancers (public)
- Virtual Network Gateways (VPN/ER)
- NAT gateways
- Application Gateways
- Azure Firewalls
- Bastion Hosts
- Route Servers
- Api Management
For Virtual Machine Scale Sets, use Public IP Prefixes.
At-a-glance
The following table shows the property a public IP can be associated to a resource and the allocation methods. Public IPv6 support isn't available for all resource types at this time.
Top-level resource | IP Address association | Dynamic IPv4 | Static IPv4 | Dynamic IPv6 | Static IPv6 |
---|---|---|---|---|---|
Virtual machine | Network interface | Yes | Yes | Yes | Yes |
Public Load balancer | Front-end configuration | Yes | Yes | Yes | Yes |
Virtual Network gateway (VPN) | Gateway IP configuration | Yes (non-AZ only) | Yes | No | No |
Virtual Network gateway (ER) | Gateway IP configuration | Yes | Yes | Yes (preview) | No |
NAT gateway | Gateway IP configuration | No | Yes | No | No |
Application Gateway | Front-end configuration | Yes (V1 only) | Yes (V2 only) | No | No |
Azure Firewall | Front-end configuration | No | Yes | No | No |
Bastion Host | Public IP configuration | No | Yes | No | No |
Route Server | Front-end configuration | No | Yes | No | No |
Api Management | Front-end configuration | No | Yes | No | No |
IP address version
Public IP addresses can be created with an IPv4 or IPv6 address. You may be given the option to create a dual-stack deployment with a IPv4 and IPv6 address.
SKU
Important
On September 30, 2025, Basic SKU public IPs will be retired. For more information, see the official announcement. If you are currently using Basic SKU public IPs, make sure to upgrade to Standard SKU public IPs prior to the retirement date. For guidance on upgrading, visit Upgrading a basic public IP address to Standard SKU - Guidance.
Public IP addresses are created with a SKU of Standard or Basic. The SKU determines their functionality including allocation method, feature support, and resources they can be associated with.
Full details are listed in the table below:
Public IP address | Standard | Basic |
---|---|---|
Allocation method | Static | For IPv4: Dynamic or Static; For IPv6: Dynamic. |
Idle Timeout | Have an adjustable inbound originated flow idle timeout of 4-30 minutes, with a default of 4 minutes, and fixed outbound originated flow idle timeout of 4 minutes. | Have an adjustable inbound originated flow idle timeout of 4-30 minutes, with a default of 4 minutes, and fixed outbound originated flow idle timeout of 4 minutes. |
Security | Secure by default model and be closed to inbound traffic when used as a frontend. Allow traffic with network security group (NSG) is required (for example, on the NIC of a virtual machine with a Standard SKU Public IP attached). | Open by default. Network security groups are recommended but optional for restricting inbound or outbound traffic. |
Availability zones | Supported. Standard IPs can be non-zonal, zonal, or zone-redundant. Zone redundant IPs can only be created in regions where 3 availability zones are live. IPs created before zones are live won't be zone redundant. | Not supported. |
Virtual machines attached to a backend pool do not need a public IP address to be attached to a public load balancer. But if they do, matching SKUs are required for load balancer and public IP resources. You can't have a mixture of basic SKU resources and standard SKU resources. You can't attach standalone virtual machines, virtual machines in an availability set resource, or a virtual machine scale set resources to both SKUs simultaneously. New designs should consider using Standard SKU resources. For more information about a standard load balancer, see Standard Load Balancer.
IP address assignment
Public IPs have two types of assignments:
Dynamic - The IP address isn't given to the resource at the time of creation when selecting dynamic. The IP is assigned when you associate the public IP address with a resource. The IP address is released when you stop, or delete the resource. Dynamic public IP addresses are commonly used for when there's no dependency on the IP address. For example, a public IP resource is released from a VM upon stop and then start. Any associated IP address is released if the allocation method is dynamic. If you don't want the IP address to change, set the allocation method to static to ensure the IP address remains the same.
Static - The resource is assigned an IP address at the time it's created. The IP address is released when the resource is deleted. When you set the allocation method to static, you cannot specify the actual IP address assigned to the public IP address resource. Azure assigns the IP address from a pool of available IP addresses in the Azure location the resource is created in.
Static public IP addresses are commonly used in the following scenarios:
- When you must update firewall rules to communicate with your Azure resources.
- DNS name resolution, where a change in IP address would require updating A records.
- Your Azure resources communicate with other apps or services that use an IP address-based security model.
- You use TLS/SSL certificates linked to an IP address.
Resource | Static | Dynamic |
---|---|---|
Standard public IPv4 | ✅ | x |
Standard public IPv6 | ✅ | x |
Basic public IPv4 | ✅ | ✅ |
Basic public IPv6 | x | ✅ |
Domain Name Label
Select this option to specify a DNS label for a public IP resource. This functionality works for both IPv4 addresses (32-bit A records) and IPv6 addresses (128-bit AAAA records). This selection creates a mapping for domainnamelabel.location.chinacloudapp.cn to the public IP in the Azure-managed DNS.
For instance, creation of a public IP with the following settings:
contoso as a domainnamelabel
China North 3 Azure location
The fully qualified domain name (FQDN) contoso.chinanorth3.cloudapp.chinacloudapi.cn resolves to the public IP address of the resource.
If a custom domain is desired for services that use a public IP, you can use Azure DNS or an external DNS provider for your DNS Record.
Domain Name Label Scope (preview)
Public IPs also have an optional parameter for Domain Name Label Scope, which defines what domain label an object with the same name will use. This feature can help to prevent "dangling DNS names" which can be reused by malicious actors. When this option is chosen, the public IP address' DNS name will have an additional string in between the domainnamelabel and location fields, e.g. contoso.fjdng2acavhkevd8.westus.cloudapp.Azure.com. (This string is a hash generated from input specific to your subscription, resource group, domain name label, and other properties).
The domain name label scope can only be specified at the creation of a public IP address.
Important
Domain Name Label Scope is currently in public preview. It's provided without a service-level agreement, and is not recommended for production workloads. For more information, see Supplemental Terms of Use for Azure Previews.
The value of the Domain Name Label Scope must match one of the options below:
Value | Behavior |
---|---|
TenantReuse | Object with the same name in the same tenant will receive the same Domain Label |
SubscriptionReuse | Object with the same name in the same subscription will receive the same Domain Label |
ResourceGroupReuse | Object with the same name in the same Resource Group will receive the same Domain Label |
NoReuse | Object with the same name will receive a new Domain Label for each new instance |
For example, if SubscriptionReuse is selected as the option, and a customer who has the example domain name label contoso.fjdng2acavhkevd8.chinanorth3.cloudapp.chinacloudapi.cn deletes and re-deploys a public IP address using the same template as before, the domain name label will remain the same. If the customer deploys a public IP address using this same template under a different subscription, the domain name label would change (e.g. *contoso.c9ghbqhhbxevhzg9.chinanorth3.cloudapp.chinacloudapi.cn).
Other public IP address features
There are other attributes that can be used for a public IP address (Standard SKU only).
The Global Tier option creates a global anycast IP that can be used with cross-region load balancers.
The Internet Routing Preference option minimizes the time that traffic spends on the Microsoft network, lowering the egress data transfer cost.
Limits
The limits for IP addressing are listed in the full set of limits for networking in Azure. The limits are per region and per subscription.
Contact support to increase above the default limits based on your business needs.
Pricing
Public IPv4 addresses have a nominal charge; Public IPv6 addresses have no charge.
To learn more about IP address pricing in Azure, review the IP address pricing page.
Limitations for IPv6
VPN gateways can't be used in a virtual network with IPv6 enabled, either directly or peered with "UseRemoteGateway".
Azure doesn't support IPv6 communication for containers.
Use of IPv6-only virtual machines or virtual machines scale sets aren't supported. Each NIC must include at least one IPv4 IP configuration (dual-stack).
IPv6 ranges can't be added to a virtual network with existing resource navigation links when adding IPv6 to existing IPv4 deployments.
Forward DNS for IPv6 is supported for Azure public DNS. Reverse DNS isn't supported.
Routing Preference Internet isn't supported.
For more information on IPv6 in Azure, see here.