你当前正在访问 Microsoft Azure Global Edition 技术文档网站。 如果需要访问由世纪互联运营的 Microsoft Azure 中国技术文档网站,请访问 https://docs.azure.cn。
New-AzVirtualNetwork
创建虚拟网络。
语法
New-AzVirtualNetwork
-Name <String>
-ResourceGroupName <String>
-Location <String>
-AddressPrefix <String[]>
[-IpamPoolPrefixAllocation <PSIpamPoolPrefixAllocation[]>]
[-DnsServer <String[]>]
[-FlowTimeout <Int32>]
[-Subnet <PSSubnet[]>]
[-BgpCommunity <String>]
[-EnableEncryption <String>]
[-EncryptionEnforcementPolicy <String>]
[-Tag <Hashtable>]
[-EnableDdosProtection]
[-DdosProtectionPlanId <String>]
[-IpAllocation <PSIpAllocation[]>]
[-EdgeZone <String>]
[-PrivateEndpointVNetPoliciesValue <String>]
[-Force]
[-AsJob]
[-DefaultProfile <IAzureContextContainer>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
说明
New-AzVirtualNetwork cmdlet 创建 Azure 虚拟网络。
示例
示例 1:创建包含两个子网的虚拟网络
New-AzResourceGroup -Name TestResourceGroup -Location centralus
$frontendSubnet = New-AzVirtualNetworkSubnetConfig -Name frontendSubnet -AddressPrefix "10.0.1.0/24"
$backendSubnet = New-AzVirtualNetworkSubnetConfig -Name backendSubnet -AddressPrefix "10.0.2.0/24"
New-AzVirtualNetwork -Name MyVirtualNetwork -ResourceGroupName TestResourceGroup -Location centralus -AddressPrefix "10.0.0.0/16" -Subnet $frontendSubnet,$backendSubnet
此示例创建包含两个子网的虚拟网络。 首先,在中心区域中创建新的资源组。 然后,该示例创建两个子网的内存中表示形式。 New-AzVirtualNetworkSubnetConfig cmdlet 不会在服务器端创建任何子网。 有一个名为 frontendSubnet 的子网和一个名为 backendSubnet 的子网。 然后,New-AzVirtualNetwork cmdlet 使用 CIDR 10.0.0.0/16 作为地址前缀和两个子网创建虚拟网络。
示例 2:使用 DNS 设置创建虚拟网络
New-AzResourceGroup -Name TestResourceGroup -Location centralus
$frontendSubnet = New-AzVirtualNetworkSubnetConfig -Name frontendSubnet -AddressPrefix "10.0.1.0/24"
$backendSubnet = New-AzVirtualNetworkSubnetConfig -Name backendSubnet -AddressPrefix "10.0.2.0/24"
New-AzVirtualNetwork -Name MyVirtualNetwork -ResourceGroupName TestResourceGroup -Location centralus -AddressPrefix "10.0.0.0/16" -Subnet $frontendSubnet,$backendSubnet -DnsServer 10.0.1.5,10.0.1.6
此示例创建一个包含两个子网和两个 DNS 服务器的虚拟网络。 在虚拟网络上指定 DNS 服务器的效果是部署到此虚拟网络的 NIC/VM 将继承这些 DNS 服务器作为默认值。 可以通过 NIC 级别设置覆盖每个 NIC 的默认值。 如果未在 VNET 上指定 DNS 服务器,并且 NIC 上没有 DNS 服务器,则默认的 Azure DNS 服务器用于 DNS 解析。
示例 3:创建包含引用网络安全组的子网的虚拟网络
New-AzResourceGroup -Name TestResourceGroup -Location centralus
$rdpRule = New-AzNetworkSecurityRuleConfig -Name rdp-rule -Description "Allow RDP" -Access Allow -Protocol Tcp -Direction Inbound -Priority 100 -SourceAddressPrefix Internet -SourcePortRange * -DestinationAddressPrefix * -DestinationPortRange 3389
$networkSecurityGroup = New-AzNetworkSecurityGroup -ResourceGroupName TestResourceGroup -Location centralus -Name "NSG-FrontEnd" -SecurityRules $rdpRule
$frontendSubnet = New-AzVirtualNetworkSubnetConfig -Name frontendSubnet -AddressPrefix "10.0.1.0/24" -NetworkSecurityGroup $networkSecurityGroup
$backendSubnet = New-AzVirtualNetworkSubnetConfig -Name backendSubnet -AddressPrefix "10.0.2.0/24" -NetworkSecurityGroup $networkSecurityGroup
New-AzVirtualNetwork -Name MyVirtualNetwork -ResourceGroupName TestResourceGroup -Location centralus -AddressPrefix "10.0.0.0/16" -Subnet $frontendSubnet,$backendSubnet
此示例创建包含引用网络安全组的子网的虚拟网络。 首先,该示例将资源组创建为将要创建的资源的容器。 然后,将创建允许入站 RDP 访问的网络安全组,但否则会强制实施默认网络安全组规则。 然后,New-AzVirtualNetworkSubnetConfig cmdlet 会创建两个子网的内存中表示形式,这些子网引用已创建的网络安全组。 然后,New-AzVirtualNetwork 命令创建虚拟网络。
示例 4:创建具有 IPAM 池的虚拟网络,以便从中为地址前缀自动分配
New-AzNetworkManagerIpamPool -ResourceGroupName "testRG" -NetworkManagerName "testNM" -Name "testIpamPool" -Location "centralus" -AddressPrefix @("10.0.0.0/16")
$ipamPool = Get-AzNetworkManagerIpamPool -ResourceGroupName "testRG" -NetworkManagerName "testNM" -Name "testIpamPool"
$ipamPoolPrefixAllocation = [PSCustomObject]@{
Id = $ipamPool.Id
NumberOfIpAddresses = "256"
}
$subnet = New-AzVirtualNetworkSubnetConfig -Name "testSubnet" -IpamPoolPrefixAllocation $ipamPoolPrefixAllocation
New-AzVirtualNetwork -Name "testVnet" -ResourceGroupName "testRG" -Location "centralus" -Subnet $subnet -IpamPoolPrefixAllocation $ipamPoolPrefixAllocation
此示例创建具有 IPAM(IP 地址管理)池的虚拟网络,以自动分配地址前缀。 首先,在 testRG 资源组中创建名为 testIpamPool 的 IPAM 池,并在中心区域中创建地址前缀为 10.0.0.0/16 的 testNM 网络管理器。 Get-AzNetworkManagerIpamPool cmdlet 检索刚刚创建的 IPAM 池。 接下来,将创建表示 IPAM 池前缀分配的自定义对象。 此对象包括 IPAM 池的 ID 和要分配的 NumberOfIpAddresses。 New-AzVirtualNetworkSubnetConfig cmdlet 创建一个名为 testSubnet 的子网,该子网配置为使用 IPAM 池前缀分配对象。 最后,New-AzVirtualNetwork cmdlet 在 testRG 资源组和中心位置创建名为 testVnet 的虚拟网络。 虚拟网络包括上一步中创建的子网,并使用 IPAM 池前缀分配进行地址前缀分配。
参数
-AddressPrefix
指定虚拟网络的 IP 地址范围。
类型: | String[] |
Position: | Named |
默认值: | None |
必需: | True |
接受管道输入: | True |
接受通配符: | False |
-AsJob
在后台运行 cmdlet
类型: | SwitchParameter |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-BgpCommunity
通过 ExpressRoute 播发的 BGP 社区。
类型: | String |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-Confirm
在运行 cmdlet 之前,提示你进行确认。
类型: | SwitchParameter |
别名: | cf |
Position: | Named |
默认值: | False |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-DdosProtectionPlanId
引用与虚拟网络关联的 DDoS 保护计划资源。
类型: | String |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-DefaultProfile
用于与 Azure 通信的凭据、帐户、租户和订阅。
类型: | IAzureContextContainer |
别名: | AzContext, AzureRmContext, AzureCredential |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-DnsServer
指定子网的 DNS 服务器。
类型: | String[] |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-EdgeZone
{{ Fill EdgeZone Description }}
类型: | String |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-EnableDdosProtection
一个开关参数,表示是否启用了 DDoS 保护。
类型: | SwitchParameter |
Position: | Named |
默认值: | False |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-EnableEncryption
指示是否在虚拟网络上启用加密。 若要在虚拟网络上启用加密,该值应为 true,否则为 false 以禁用加密。
类型: | String |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-EncryptionEnforcementPolicy
设置 Encryption EnforcementPolicy。 应允许 AllowUnencrypted 允许在加密虚拟网络中没有加密功能的 VM,或者 dropUnencrypted 禁用任何 VM,而无需将加密功能添加到加密的虚拟网络中。
类型: | String |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-FlowTimeout
FlowTimeout 为 VM 内部流启用连接跟踪。 该值应介于 4 到 30 分钟(含)之间,以启用跟踪,或为 null 以禁用跟踪。
类型: | Nullable<T>[Int32] |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-Force
强制命令运行而不要求用户确认。
类型: | SwitchParameter |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
-IpAllocation
指定虚拟网络的 IpAllocations。
类型: | PSIpAllocation[] |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-IpamPoolPrefixAllocation
指定要从中为虚拟网络地址前缀自动分配的 PSIpamPoolPrefixAllocation 对象的列表。
类型: | PSIpamPoolPrefixAllocation[] |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-Location
指定虚拟网络的区域。
类型: | String |
Position: | Named |
默认值: | None |
必需: | True |
接受管道输入: | True |
接受通配符: | False |
-Name
指定此 cmdlet 创建的虚拟网络的名称。
类型: | String |
别名: | ResourceName |
Position: | Named |
默认值: | None |
必需: | True |
接受管道输入: | True |
接受通配符: | False |
-PrivateEndpointVNetPoliciesValue
虚拟网络的 PrivateEndpointVNetPolicies
类型: | String |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-ResourceGroupName
指定要包含虚拟网络的资源组的名称。
类型: | String |
Position: | Named |
默认值: | None |
必需: | True |
接受管道输入: | True |
接受通配符: | False |
-Subnet
指定要与虚拟网络关联的子网列表。
类型: | PSSubnet[] |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-Tag
以哈希表的形式进行键值对。 例如:@{key0=“value0”;key1=$null;key2=“value2”}
类型: | Hashtable |
Position: | Named |
默认值: | None |
必需: | False |
接受管道输入: | True |
接受通配符: | False |
-WhatIf
显示 cmdlet 运行时会发生什么情况。 cmdlet 未运行。
类型: | SwitchParameter |
别名: | wi |
Position: | Named |
默认值: | False |
必需: | False |
接受管道输入: | False |
接受通配符: | False |
输入
String[]
PSSubnet[]