Product Documentation

虚拟 IP 和虚拟环回

Mar 17, 2016
注意:这些功能仅对 Windows Server 2008 R2 和 Windows Server 2012 R2 计算机有效。 不适用于 Windows 桌面操作系统计算机。

Microsoft 虚拟 IP 地址功能为每个会话的已发布应用程序提供动态分配的唯一 IP 地址。 借助 Citrix 虚拟环回功能,可以将依赖于与 localhost(默认为 127.0.0.1)通信的应用程序配置为使用 localhost 范围 (127.*) 之内的唯一虚拟环回地址。

一些应用程序(例如 CRM 和计算机电话集成 (CTI))将 IP 地址用于寻址、许可、身份验证或其他目的,因此,这些应用程序在会话中需要使用唯一的 IP 地址或环回地址。 其他应用程序可能绑定到某个静态端口,因此,在多用户环境中尝试启动应用程序的其他实例将失败,因为该端口已在使用中。 要使这些应用程序能够在 XenApp 环境中正常运行,需要为每个设备设置唯一的 IP 地址。

虚拟 IP 和虚拟环回是两个独立的功能。 可以使用其中一项功能,也可以同时使用两项功能。

管理员操作摘要:
  • 要使用 Microsoft 虚拟 IP,请在 Windows 服务器上启用并配置此功能。
  • 要使用 Citrix 虚拟环回,请在 Citrix 策略中配置两项设置。

虚拟 IP

在 Windows 服务器上启用并配置虚拟 IP 后,会话中运行的每个已配置应用程序显示为具有唯一的地址。 用户可以在 XenApp 服务器上访问这些应用程序,访问方式与访问任何其他已发布应用程序的方式相同。 进程在以下情况下需要虚拟 IP:
  • 进程使用硬编码的 TCP 端口号
  • 进程使用 Windows 套接字并需要唯一 IP 地址或指定的 TCP 端口号
确定应用程序是否需要使用虚拟 IP 地址:
  1. 获得 Microsoft 提供的 TCPView 工具。 此工具可以列出所有绑定特定 IP 地址和端口的应用程序。
  2. 禁用“解析 IP 地址”功能,这样您看到的将是地址而不是主机名。
  3. 启动应用程序,然后使用 TCPView 查看该应用程序打开了哪些 IP 地址和端口以及哪些进程名称正在打开这些端口。
  4. 配置任何打开服务器的 IP 地址(0.0.0.0 或 127.0.0.1)的进程。
  5. 为确保应用程序不会在其他端口上打开相同的 IP 地址,请启动该应用程序的另一实例。
Microsoft 远程桌面 (RD) IP 虚拟化的工作方式
  • 必须在 Microsoft 服务器上启用虚拟 IP 地址。

    例如,在 Windows Server 2008 R2 环境中,从服务器管理器,展开“远程桌面服务”>“RD 会话主机连接”以启用 RD IP 虚拟化功能,并配置设置以使用动态主机配置协议 (DHCP) 服务器基于每个会话或每个程序动态分配 IP 地址。 请参阅 Microsoft 文档以了解相关说明。

  • 启用此功能后,服务器将在会话启动时从 DHCP 服务器请求动态分配的 IP 地址。
  • RD IP 虚拟化功能在每会话或每程序基础上将 IP 地址分配给远程桌面连接。 如果为多个程序分配 IP 地址,则它们将共享每会话 IP 地址。
  • 将地址分配给会话后,该会话将在进行以下调用时使用分配的虚拟地址,而不是系统的主 IP 地址:Bind、closesocket、connect、WSAConnect、WSAAccept、getpeername、getsockname、sendto、WSASendTo、WSASocketW、gethostbyaddr、getnameinfo 和 getaddrinfo

在“远程桌面”会话托管配置中使用 Microsoft IP 虚拟化功能时,在应用程序和 Winsock 函数调用之间插入“过滤器”组件,可将该应用程序绑定到特定的 IP 地址。 然后,应用程序只能看到自己应该使用的 IP 地址。 该应用程序对侦听 TCP 或 UDP 通信的任何尝试都会自动绑定到其分配的虚拟 IP 地址(或环回地址),并且该应用程序打开的任何原始连接都源自绑定到该应用程序的 IP 地址。

在返回地址的函数(如 GetAddrInfo(),由 Windows 策略控制)中,如果请求本地主机 IP 地址,则虚拟 IP 将查看返回的 IP 地址并将其更改为会话的虚拟 IP 地址。 尝试通过此类名称函数获得本地服务器 IP 地址的应用程序,仅会看到分配给该会话的唯一虚拟 IP 地址。 此 IP 地址通常用于后续套接字调用,如 bind 或 connect。

通常,应用程序会请求绑定到一个端口以侦听地址 0.0.0.0。 如果应用程序发出此请求并使用静态端口,您无法启动该应用程序的多个实例。 虚拟 IP 地址功能也会在这些类型的调用中查找 0.0.0.0,然后将调用更改为侦听特定虚拟 IP 地址。这样一来,多个应用程序便可侦听同一台计算机上的同一端口,因为这些应用程序侦听的地址是各不相同的。 仅当调用在 ICA 会话中进行并且虚拟 IP 地址功能处于启用状态时,才可以更改调用。 例如,如果在不同会话中运行的应用程序的两个实例同时尝试绑定到所有接口 (0.0.0.0) 和特定端口(例如 9000),它们将分别绑定到 VIPAddress1:9000 和 VIPAddress2:9000,因而不会发生冲突。

虚拟环回

启用 Citrix 虚拟 IP 环回策略设置后,每个会话都可以拥有自己的通信用虚拟环回地址。 如果应用程序在 Winsock 调用中使用了 localhost 地址(默认为 127.0.0.1),虚拟环回功能只将 127.0.0.1 替换为 127.X.X.X,其中 X.X.X 表示会话 ID + 1。 例如,会话 ID 为 7 的地址是 127.0.0.8。 万一会话 ID 超过第四个八位字节(大于 255),地址将滚动到下一个八位字节 (127.0.1.0),直至达到最大值 127.255.255.255。

进程在以下情况下需要虚拟环回:
  • 进程使用 Windows 套接字环回 (localhost) 地址 (127.0.0.1)
  • 进程使用硬编码的 TCP 端口号
虚拟环回策略设置应用于使用环回地址进行进程间通信的应用程序。 无需执行其他配置。 虚拟环回独立于虚拟 IP,因此无需配置 Microsoft 服务器。
  • 虚拟 IP 环回支持。 启用后,此策略设置允许每个会话有其自己的虚拟环回地址。 默认情况下,此设置处于禁用状态。 此功能仅适用于虚拟 IP 虚拟环回程序列表策略设置指定的应用程序。
  • 虚拟 IP 虚拟环回程序列表。 此策略设置指定使用虚拟 IP 环回功能的应用程序。 此设置仅在启用了虚拟 IP 环回支持策略设置时有效。

相关功能

可以使用以下注册表设置来确保虚拟环回的优先级高于虚拟 IP;这称为环回优先。 但是,操作时请注意以下事项:
  • 环回优先仅在 Windows 2008 R2 上受支持。
  • 仅在同时启用了虚拟 IP 和虚拟环回的情况下使用环回优先;否则可能会导致意外结果。
  • 注册表编辑不当可能会导致严重问题,可能需要重新安装操作系统。 Citrix 无法保证因“注册表编辑器”使用不当导致出现的问题能够得以解决。 使用“注册表编辑器”需自担风险。 在编辑注册表之前,请务必进行备份。
在应用程序所在的服务器运行注册表。
  • HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Citrix\VIP(对于 32 位计算机为 HKEY_LOCAL_MACHINE\SOFTWARE\Citrix\VIP)
  • 名称:PreferLoopback,类型:REG_DWORD,数据:1
  • 名称:PreferLoopbackProcesses,类型:REG_MULTI_SZ,数据:<进程列表>