与基于 Windows 的 Azure 虚拟机 (VM) 的远程桌面协议 (RDP) 连接可能会因各种原因而失败,使用户无法访问 VM。 问题可能出在 VM 上的远程桌面服务、网络连接或主计算机上的远程桌面客户端。 本文介绍解决 RDP 连接问题的一些最常见方法。
如果对本文中的任何观点存在疑问,可以联系 MSDN Azure 和 CSDN Azure上的 Azure 专家。 或者,也可以提交 Azure 支持事件。 请转到 Azure 支持站点并选择“获取支持”。
快速故障排除步骤
在执行每个故障排除步骤之后,请尝试连接到 VM:
- 重置远程桌面配置。
- 检查网络安全组规则/云服务终结点。
- 查看 VM 控制台日志。
- 重置 VM 的 NIC。
- 重置 VM 密码。
- 重新启动 VM。
- 重新部署 VM。
如需更详细的步骤和说明,请继续阅读余下的内容。 请确保本地网络设备(如路由器和防火墙)未阻止出站 TCP 端口 3389,如 RDP 详细故障排除方案中所述。
Tip
如果门户中 VM 的“连接”按钮不可用,并且用户未通过 Express Route 或站点到站点 VPN 连接来连接到 Azure,则必须先为 VM 创建并分配一个公共 IP 地址,然后才能使用 RDP。 详细了解 Azure 中的公共 IP 地址。
排查 RDP 问题的方法
可以使用以下方法之一,对使用 Resource Manager 部署模型创建的 VM 进行故障排除:
- Azure 门户 - 如果需要快速重置 RDP 配置或用户凭据,并且没有安装 Azure 工具,则很适合使用此方法。
- Azure PowerShell - 如果很熟练 PowerShell 提示符,可以使用 Azure PowerShell cmdlet 快速重置 RDP 配置或用户凭据。
还可以查找有关针对使用 经典部署模型创建的 VM 进行故障排除的步骤。
使用 Azure 门户进行故障排除
在执行每个故障排除步骤之后,请尝试再次连接到 VM。 如果仍然无法连接,请尝试下一步。
-
重置 RDP 连接。 当“远程连接”已禁用或 Windows 防火墙规则阻止 RDP 时,此故障排除步骤可重置 RDP 配置。
在 Azure 门户中选择 VM。 在“设置”窗格中向下滚动到靠近列表底部的“支持 + 故障排除”部分。 单击“重置密码”按钮。 将“模式”设置为“仅重置配置”,然后单击“更新”按钮:
验证网络安全组规则。 可以查看生效的安全组规则,确保入站“允许”NSG 规则存在并已针对 RDP 端口(默认为 3389)设置优先级。 有关详细信息,请参阅使用有效的安全规则排查 VM 流量流问题。
-
检查 VM 启动诊断。 此故障排除步骤检查 VM 控制台日志,确定 VM 是否报告了问题。 并非所有 VM 都已启用启动诊断,因此,此故障排除步骤可能是可选的。
本文未介绍具体的故障排除步骤,而是指出会影响 RDP 连接的更广泛问题。 有关查看控制台日志和 VM 屏幕截图的详细信息,请参阅 Boot Diagnostics for VMs(VM 的启动诊断)。
重置 VM 的 NIC。 有关详细信息,请参阅如何重置 Azure Windows VM 的 NIC。
-
重置用户凭据。 不确定或者忘了凭据时,可以使用此故障排除步骤重置本地管理员帐户的密码。
在 Azure 门户中选择 VM。 在“设置”窗格中向下滚动到靠近列表底部的“支持 + 故障排除”部分。 单击“重置密码”按钮。 确保“模式”已设置为“重置密码”,然后输入用户名和新密码。 Finally, click the Update button:
-
重新启动 VM。 此故障排除步骤可以解决 VM 本身存在的任何基本问题。
在 Azure 门户中选择 VM,并单击“概述”选项卡。
-
重新部署 VM。 此故障排除步骤可将 VM 重新部署到 Azure 中的另一台主机,从而解决平台或网络的任何基本问题。
在 Azure 门户中选择 VM。 在“设置”窗格中向下滚动到靠近列表底部的“支持 + 故障排除”部分。 单击“重新部署”按钮,然后单击“重新部署”:
完成此操作后,会丢失临时磁盘数据,系统会更新与 VM 关联的动态 IP 地址。
如果仍遇到 RDP 问题,可以开具支持请求或阅读更详细的 RDP 故障排除概念和步骤。
使用 Azure PowerShell 进行故障排除
如果尚未执行该操作,请安装并配置最新的 Azure PowerShell。
以下示例使用 myResourceGroup
、myVM
、myVMAccessExtension
之类的变量。 请将这些变量名称和位置替换为自己的值。
Note
使用 Set-AzureRmVMAccessExtension PowerShell cmdlet 重置用户凭据和 RDP 配置。 在以下示例中, myVMAccessExtension
是在重置过程中指定的名称。 如果以前使用过 VMAccessAgent,可以使用 Get-AzureRmVM -ResourceGroupName "myResourceGroup" -Name "myVM"
检查 VM 的属性,从而获取现有的扩展名称。 若要查看名称,请查看输出的“Extensions”节中的内容。
在执行每个故障排除步骤之后,请尝试再次连接到 VM。 如果仍然无法连接,请尝试下一步。
-
重置 RDP 连接。 当“远程连接”已禁用或 Windows 防火墙规则阻止 RDP 时,此故障排除步骤可重置 RDP 配置。
以下示例将在
ChinaNorth
位置和名为myResourceGroup
资源组中重置名为myVM
的 VM 上的 RDP 连接:PowerShell复制Set-AzureRmVMAccessExtension -ResourceGroupName "myResourceGroup" `
-VMName "myVM" -Location Westus -Name "myVMAccessExtension" -
验证网络安全组规则。 此故障排除步骤验证网络安全组中是否存在允许 RDP 流量的规则。 RDP 的默认端口为 TCP 端口 3389。 创建 VM 时,可能不会自动创建允许 RDP 流量的规则。
首先,将网络安全组的所有配置数据分配到
$rules
变量。 以下示例将在名为myResourceGroup
的资源组中获取关于名为myNetworkSecurityGroup
的网络安全组的信息:PowerShell复制$rules = Get-AzureRmNetworkSecurityGroup -ResourceGroupName "myResourceGroup" `
-Name "myNetworkSecurityGroup"现在,查看针对此网络安全组配置的规则。 验证是否存在一个允许使用 TCP 端口 3389 进行入站连接的规则,如下所示:
PowerShell复制$rules.SecurityRules
以下示例显示了一个允许 RDP 流量的有效安全规则。 可以看到
Protocol
、DestinationPortRange
、Access
和Direction
已正确配置:PowerShell复制Name : default-allow-rdp
Id : /subscriptions/guid/resourceGroups/myResourceGroup/providers/Microsoft.Network/networkSecurityGroups/myNetworkSecurityGroup/securityRules/default-allow-rdp
Etag :
ProvisioningState : Succeeded
Description :
Protocol : TCP
SourcePortRange : *
DestinationPortRange : 3389
SourceAddressPrefix : *
DestinationAddressPrefix : *
Access : Allow
Priority : 1000
Direction : Inbound如果不存在允许 RDP 通信的规则,请创建网络安全组规则。 允许 TCP 端口 3389。
-
重置用户凭据。 不确定或者忘了凭据时,可以使用此故障排除步骤重置指定的本地管理员帐户的密码。
首先,通过将凭据分配到
$cred
变量来指定用户名和新密码,如下所示:PowerShell复制$cred=Get-Credential
接下来,更新 VM 上的凭据。 以下示例将在
ChinaNorth
位置中和名为myResourceGroup
的资源组中更新名为myVM
的 VM 上的凭据:PowerShell复制Set-AzureRmVMAccessExtension -ResourceGroupName "myResourceGroup" `
-VMName "myVM" -Location ChinaNorth -Name "myVMAccessExtension" `
-UserName $cred.GetNetworkCredential().Username `
-Password $cred.GetNetworkCredential().Password -
重新启动 VM。 此故障排除步骤可以解决 VM 本身存在的任何基本问题。
以下示例重启
myResourceGroup
资源组中名为myVM
的 VM:PowerShell复制Restart-AzureRmVM -ResourceGroup "myResourceGroup" -Name "myVM"
-
重新部署 VM。 此故障排除步骤可将 VM 重新部署到 Azure 中的另一台主机,从而解决平台或网络的任何基本问题。
以下示例重新部署
ChinaNorth
位置和myResourceGroup
资源组中名为myVM
的 VM:PowerShell复制Set-AzureRmVM -Redeploy -ResourceGroupName "myResourceGroup" -Name "myVM"
如果仍遇到 RDP 问题,可以开具支持请求或阅读更详细的 RDP 故障排除概念和步骤。
对使用经典部署模型创建的 VM 进行故障排除
执行每个故障排除步骤后,请尝试重新连接到 VM。
-
重置 RDP 连接。 当“远程连接”已禁用或 Windows 防火墙规则阻止 RDP 时,此故障排除步骤可重置 RDP 配置。
在 Azure 门户中选择 VM。 单击“...更多”按钮,然后单击“重置远程访问”:
-
验证云服务终结点。 此故障排除步骤验证云服务中是否存在允许 RDP 流量的终结点。 RDP 的默认端口为 TCP 端口 3389。 创建 VM 时,可能不会自动创建允许 RDP 流量的规则。
在 Azure 门户中选择 VM。 单击“终结点”按钮以查看当前为 VM 配置的终结点。 验证终结点存在,它们允许 TCP 端口 3389 上的 RDP 通信。
以下示例显示了允许 RDP 流量的有效终结点:
如果不存在允许 RDP 通信的终结点,请创建云服务终结点。 允许使用 TCP 连接到专用端口 3389。
-
检查 VM 启动诊断。 此故障排除步骤检查 VM 控制台日志,确定 VM 是否报告了问题。 并非所有 VM 都已启用启动诊断,因此,此故障排除步骤可能是可选的。
本文未介绍具体的故障排除步骤,而是指出会影响 RDP 连接的更广泛问题。 有关查看控制台日志和 VM 屏幕截图的详细信息,请参阅 Boot Diagnostics for VMs(VM 的启动诊断)。
-
检查 VM 资源运行状况。 此故障排除步骤验证 Azure 平台上是否未出现任何可能影响 VM 连接的已知问题。
在 Azure 门户中选择 VM。 在“设置”窗格中向下滚动到靠近列表底部的“支持 + 故障排除”部分。 单击“资源运行状况”按钮。 A healthy VM reports as being Available:
-
重置用户凭据。 不确定或者忘了凭据时,可以使用此故障排除步骤重置指定的本地管理员帐户的密码。
在 Azure 门户中选择 VM。 在“设置”窗格中向下滚动到靠近列表底部的“支持 + 故障排除”部分。 单击“重置密码”按钮。 输入用户名和新密码。 最后,单击“保存”按钮:
-
重新启动 VM。 此故障排除步骤可以解决 VM 本身存在的任何基本问题。
在 Azure 门户中选择 VM,并单击“概述”选项卡。
如果仍遇到 RDP 问题,可以开具支持请求或阅读更详细的 RDP 故障排除概念和步骤。
排查特定的 RDP 错误
尝试通过 RDP 连接到 VM 时,可能会遇到特定的错误消息。 以下是最常见的错误消息:
- 由于没有可用于提供许可证的远程桌面授权服务器,远程会话已断开连接。
- 远程桌面找不到计算机“名称”。
- 身份验证出错。无法联系本地安全机构。
- Windows 安全性错误:凭据无效。
- 此计算机无法连接到远程计算机。
其他资源
如果未发生上述任何错误但仍无法通过远程桌面连接到 VM,请阅读详细的远程桌面故障排除指南。
- 有关用于访问 VM 上运行的应用程序的故障排除步骤,请参阅对在 Azure VM 上运行的应用程序的访问进行故障排除。
- 如果在 Azure 中使用 Secure Shell (SSH) 连接到 Linux VM 时遇到问题,请参阅对 Azure 中到 Linux VM 的 SSH 连接进行故障排除。立即访问http://market.azure.cn