本教程需要 Azure PowerShell 模块 3.6 或更高版本。 运行
Get-Module -ListAvailable AzureRM
即可查找版本。 如果需要进行升级,请参阅
Install Azure PowerShell module
(安装 Azure PowerShell 模块)。 如果在本地运行 PowerShell,则还需运行
Login-AzureRmAccount -EnvironmentName AzureChinaCloud
以创建与 Azure 的连接。
创建资源组
使用
New-AzureRmResourceGroup
命令创建资源组。
Azure 资源组是在其中部署和管理 Azure 资源的逻辑容器。 必须在创建虚拟机前创建资源组。 在此示例中,在“ChinaEast”区域中创建了名为“myResourceGroupVM”的资源组。
New-AzureRmResourceGroup -ResourceGroupName myResourceGroupVM -Location ChinaEast
创建或修改 VM 时指定资源组,本教程会对此进行演示。
创建虚拟机
虚拟机必须连接到虚拟网络。 可以通过网络接口卡使用公共 IP 地址与虚拟机通信。
创建虚拟网络
使用 New-AzureRmVirtualNetworkSubnetConfig 创建子网:
$subnetConfig = New-AzureRmVirtualNetworkSubnetConfig `
-Name mySubnet `
-AddressPrefix 192.168.1.0/24
使用 New-AzureRmVirtualNetwork 创建虚拟网络:
$vnet = New-AzureRmVirtualNetwork `
-ResourceGroupName myResourceGroupVM `
-Location ChinaEast `
-Name myVnet `
-AddressPrefix 192.168.0.0/16 `
-Subnet $subnetConfig
创建公共 IP 地址
使用 New-AzureRmPublicIpAddress 创建一个公共 IP 地址:
$pip = New-AzureRmPublicIpAddress `
-ResourceGroupName myResourceGroupVM `
-Location ChinaEast `
-AllocationMethod Static `
-Name myPublicIPAddress
创建网络接口卡
使用 New-AzureRmNetworkInterface 创建网络接口卡:
$nic = New-AzureRmNetworkInterface `
-ResourceGroupName myResourceGroupVM `
-Location ChinaEast `
-Name myNic `
-SubnetId $vnet.Subnets[0].Id `
-PublicIpAddressId $pip.Id
创建网络安全组
Azure 网络安全组 (NSG) 控制一个或多个虚拟机的入站和出站流量。 网络安全组规则允许或拒绝特定端口上或端口范围内的网络流量。 这些规则还可包括源地址前缀,这样只有源自预定义源的流量才可与虚拟机进行通信。 若要访问正安装的 IIS web 服务器,必须添加入站 NSG 规则。
若要创建入站 NSG 规则,请使用 Add-AzureRmNetworkSecurityRuleConfig。 以下示例创建名为“myNSGRule”的 NSG 规则,这将为虚拟机打开端口 3389:
$nsgRule = New-AzureRmNetworkSecurityRuleConfig `
-Name myNSGRule `
-Protocol Tcp `
-Direction Inbound `
-Priority 1000 `
-SourceAddressPrefix * `
-SourcePortRange * `
-DestinationAddressPrefix * `
-DestinationPortRange 3389 `
-Access Allow
将 myNSGRule 与 New-AzureRmNetworkSecurityGroup 结合使用,创建 NSG:
$nsg = New-AzureRmNetworkSecurityGroup `
-ResourceGroupName myResourceGroupVM `
-Location ChinaEast `
-Name myNetworkSecurityGroup `
-SecurityRules $nsgRule
使用 Set-AzureRmVirtualNetworkSubnetConfig 将 NSG 添加到虚拟网络中的子网:
Set-AzureRmVirtualNetworkSubnetConfig `
-Name mySubnet `
-VirtualNetwork $vnet `
-NetworkSecurityGroup $nsg `
-AddressPrefix 192.168.1.0/24
使用 Set-AzureRmVirtualNetwork 更新虚拟网络:
Set-AzureRmVirtualNetwork -VirtualNetwork $vnet
创建虚拟机
创建虚拟机时,可使用多个选项,例如操作系统映像、磁盘大小调整和管理凭据。 在此示例中,将创建名为“myVM”的虚拟机,它运行最新版本的 Windows Server 2016 Datacenter。
使用 Get-Credential 设置虚拟机上管理员帐户所需的用户名和密码:
$cred = Get-Credential
使用 New-AzureRmVMConfig 为虚拟机创建初始配置:
$vm = New-AzureRmVMConfig -VMName myVM -VMSize Standard_D1
使用 Set-AzureRmVMOperatingSystem 向虚拟机配置添加操作系统信息:
$vm = Set-AzureRmVMOperatingSystem `
-VM $vm `
-Windows `
-ComputerName myVM `
-Credential $cred `
-ProvisionVMAgent -EnableAutoUpdate
使用 Set-AzureRmVMSourceImage 向虚拟机配置添加映像信息:
$vm = Set-AzureRmVMSourceImage `
-VM $vm `
-PublisherName MicrosoftWindowsServer `
-Offer WindowsServer `
-Skus 2016-Datacenter `
-Version latest
使用 Set-AzureRmVMOSDisk 向虚拟机配置添加操作系统磁盘设置:
$vm = Set-AzureRmVMOSDisk `
-VM $vm `
-Name myOsDisk `
-DiskSizeInGB 128 `
-CreateOption FromImage `
-Caching ReadWrite
使用 Add-AzureRmVMNetworkInterface 向虚拟机配置添加以前创建的网络接口卡:
$vm = Add-AzureRmVMNetworkInterface -VM $vm -Id $nic.Id
使用 New-AzureRmVM 创建虚拟机。
New-AzureRmVM -ResourceGroupName myResourceGroupVM -Location ChinaEast -VM $vm
连接到 VM
在部署完成后,创建到虚拟机的远程桌面连接。
运行以下命令,以返回虚拟机的公共 IP 地址。 需记下此 IP 地址,以便在后续步骤中使用浏览器连接到它测试 Web 连接。
Get-AzureRmPublicIpAddress -ResourceGroupName myResourceGroupVM | Select IpAddress
使用以下命令创建与虚拟机的远程桌面会话。 将 IP 地址替换为虚拟机的 publicIPAddress。 出现提示时,输入创建虚拟机时使用的凭据。
mstsc /v:<publicIpAddress>
了解 VM 映像
Azure 应用商店包括许多可用于新建虚拟机的虚拟机映像。 在之前的步骤中,使用 Windows Server 2016 Datacenter 映像创建了虚拟机。 在此步骤中,使用 PowerShell 模块在应用商店搜索其他 Windows 映像,这些映像也可充当新 VM 的基础。 此过程包括查找发布者、产品/服务和映像名称 (Sku)。
使用 Get AzureRmVMImagePublisher 命令返回映像发布者的列表。
Get-AzureRmVMImagePublisher -Location "ChinaEast"
使用 Get AzureRmVMImageOffer 返回映像产品/服务的列表。 使用此命令,返回筛选了特定发布者的列表。
Get-AzureRmVMImageOffer -Location "ChinaEast" -PublisherName "MicrosoftWindowsServer"
Offer PublisherName Location
----- ------------- --------
Windows-HUB MicrosoftWindowsServer ChinaEast
WindowsServer MicrosoftWindowsServer ChinaEast
WindowsServer-HUB MicrosoftWindowsServer ChinaEast
然后,使用 Get AzureRmVMImageSku 命令对发布者和产品/服务名称进行筛选,以返回映像名称的列表。
Get-AzureRmVMImageSku -Location "ChinaEast" -PublisherName "MicrosoftWindowsServer" -Offer "WindowsServer"
Skus Offer PublisherName Location
---- ----- ------------- --------
2008-R2-SP1 WindowsServer MicrosoftWindowsServer ChinaEast
2008-R2-SP1-zhcn WindowsServer MicrosoftWindowsServer ChinaEast
2012-Datacenter WindowsServer MicrosoftWindowsServer ChinaEast
2012-Datacenter-zhcn WindowsServer MicrosoftWindowsServer ChinaEast
2012-R2-Datacenter WindowsServer MicrosoftWindowsServer ChinaEast
2012-R2-Datacenter-zhcn WindowsServer MicrosoftWindowsServer ChinaEast
2016-Datacenter WindowsServer MicrosoftWindowsServer ChinaEast
2016-Datacenter-Server-Core WindowsServer MicrosoftWindowsServer ChinaEast
2016-Datacenter-with-Containers WindowsServer MicrosoftWindowsServer ChinaEast
2016-Nano-Server WindowsServer MicrosoftWindowsServer ChinaEast
此信息可用于部署具有特定映像的 VM。 此示例为 VM 对象设置映像名称。 请参阅本教程前面的示例,了解完整的部署步骤。
$vm = Set-AzureRmVMSourceImage `
-VM $vm `
-PublisherName MicrosoftWindowsServer `
-Offer WindowsServer `
-Skus 2016-Datacenter-with-Containers `
-Version latest
了解 VM 大小
虚拟机大小决定虚拟机可用计算资源(如 CPU、GPU 和内存)的数量。 创建的虚拟机大小需适合预期的工作负荷。 如果工作负荷增加,可调整现有虚拟机的大小。
VM 大小
下表将大小分类成了多个用例。
类型大小说明
DSv2、Dv2、DS、D、Av2、A0-7
CPU 与内存之比均衡。 适用于开发/测试、小到中型应用程序和数据解决方案。
Fs, F
高 CPU 与内存之比。 适用于中等流量的应用程序、网络设备和批处理。
GS, G, DSv2, DS, Dv2, D
较高的内存核心比。 适用于关系数据库、中到大型缓存和内存中分析。
高磁盘吞吐量和 IO。 适用于大数据、SQL 和 NoSQL 数据库。
NV, NC
专门针对大量图形绘制和视频编辑的 VM。
H, A8-11
功能极其强大的 CPU VM 具有可选的高吞吐量网络接口 (RDMA)。
查找可用的 VM 大小
若要查看在特定区域可用的 VM 大小的列表,请使用 Get-AzureRmVMSize 命令。
Get-AzureRmVMSize -Location ChinaEast
调整 VM 的大小
部署 VM 后,可调整其大小以增加或减少资源分配。
调整 VM 大小之前,请检查所需的大小在当前 VM 群集上是否可用。 使用 Get AzureRmVMSize 命令返回大小的列表。
Get-AzureRmVMSize -ResourceGroupName myResourceGroupVM -VMName myVM
如果所需大小可用,则可从开机状态调整 VM 大小,但需在此操作期间重启 VM。
$vm = Get-AzureRmVM -ResourceGroupName myResourceGroupVM -VMName myVM
$vm.HardwareProfile.VmSize = "Standard_D4"
Update-AzureRmVM -VM $vm -ResourceGroupName myResourceGroupVM
如果所需大小在当前群集上不可用,则需解除分配 VM,然后才能执行调整大小操作。 请注意,重新启动 VM 时会删除临时磁盘上的任何数据,并且如果不使用静态 IP 地址,则公共 IP 地址会发生更改。
Stop-AzureRmVM -ResourceGroupName myResourceGroupVM -Name "myVM" -Force
$vm = Get-AzureRmVM -ResourceGroupName myResourceGroupVM -VMName myVM
$vm.HardwareProfile.VmSize = "Standard_F4s"
Update-AzureRmVM -VM $vm